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In this Issue: 

w ' lnoul computers, much of our modern society would cease to function Most of us 
! wouldn't receive our paychecks — or bills, for that matter — and governments and corporations 
would choke on the vast amount of information they must process to survive, 
jgjljjj For every application in which a computer is effective, a programmer or group of program- 
mers has had to write an application program, a detailed set of instructions that tells the 
computer how to handle every conceivable situation These programs are also called applica- 
^ > , ' on software packages or application systems. The subject of this month's cover and the 

Hfc ' J^ZSM article on page 3 is an application system that runs on an HP 3000 Computer Called Materials 
Management'3000, it's designed to help manufacturers improve productivity as they deal with the challenges of 
cost pressures, shipment schedules, and production line efficiency. For example, this system helps optimize a 
company's investment in inventory — too little leads to late shipments and unhappy customers; too much means 
higher carrying costs and money tied up unproductively. 

Although more and more business operations are being put under the control of computer application 
systems, installing these systems isn't always a routine job. All too common are stories of how this firm or that 
has installed a computer and then gone back to a manual system after months of frustration. Either the 
application system was badly designed, or it couldn't be adapted to a particular firm's operations, or the using 
firm found that it needed a staff of programmers to modify the system and maintain it on a day-to-day basis. In 
many cases the costs can exceed the benefits. 

Materials Management 3000 is innovative because it's designed to be tailored easily to a particular company's 
operations without a staff of computer professionals. What's more, after the system is customized by the using 
manufacturer, HP can and will continue to maintain and support it. This is possible because the basic program 
instructions are kept separate from the customizable parts, so they don't change when the system is customized. 
Two special software utilities called the Application Customizer (page 13) and the Application Monitor (page 
19) are largely responsible for these benefits. They're parts of Materials Management' 3000, and they'll also be 
used by HP designers to create new application systems to help companies operate more productively. 

On page 23 you'll find an article about a new high-performance digital voltmeter. Model 3456A. It' s characteris- 
tic of digital voltmeters that they take a long time when they're making relatively precise voltage measurements, 
say six digits, but they're much faster on less precise measurements, say three or four digits. The 3456A's 
designers have developed a new measurement technique that gives more precision in less time than previous 
designs. They've given it a name— Multi-Slope II. It'll give you 330 four-digit readings per second or 48 six-digit 
readings per second. The 3456A is accurate enough to be considered a transfer standard, with accuracy 
traceable to the United States National Bureau of Standards. But it's not just a laboratory instrument, it's also 
designed for use in automatic computer-controlled systems. It can accept, remember, and execute a measure- 
ment program loaded into it by a computer and signal the computer when it's ready with the result. There are 
many other nice features in the 3456A. such as the ability to take measurements from a thermistor and display 
temperatures in degrees, and compensation for voltage offsets in resistance measurements. Read the article for 
the full design story. 
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An Interactive Material Planning and 
Control System for Manufacturing 
Companies 

Drawing on HP's own experience, this powerful software 
for the HP 3000 Computer makes it easier to deal with the 
complexities of operating a manufacturing company. 

by Nancy C. Federman and Robert M. Steiner 



SO YOU WANT TO BE AN ENTREPRENEUR. Let's 
assume that you have already invented that hot 
item and you have procured sufficient venture 
capital. Do you really know what is involved in manufac- 
turing a product: The first step is to specify the engineer- 
ing data. What is the structure of the product? You need to 
determine the parts and subassemblies that go into the 
product and the quantities of each required per unit. 
Which of these components will you manufacture? Which 
will you subcontract to other manufacturing companies, 
and which will you purchase? 

Now that you ha ve some of the engineering specifications 
the next step is to determine the manufacturing procedure. 
How is the product to be made? You will need to decide the 
manufacturing operations necessary to construct the prod- 
uct and then specify the locations in your shop where the 
work will be done (i.e.. the workstations). The sequence of 
these production steps, called the routing, plus the labor 
and material required in each operation, must be detailed. 

The product is specified and the manufacturing plant and 
process are established. You are now ready to begin produc- 
tion. How many products should you build? You need to 
consider customer demand, current and forecast, as well as 
the capacity constraints of the factory. Once your produc- 
tion plan is established you need to determine your material 
requirements. How many component parts do you need to 
meet your production schedule? You also need to deter- 
mine the schedule of production for the manufactured 
components. When do the purchased parts have to be or- 
dered? You need to balance the desire to have components 
always available with the economic necessity of keeping 
inventory levels as low as possible. 

Controls are needed to monitor the flow of materials in 
the stockroom and on the factory floor. When do the com- 
ponent parts need to be issued to the production lines and 
what quantities are required? You will want to monitor the 
shop floor and track the work in process. How much mate- 
rial is wasted? How efficient is your work force? When the 
products are finally completed you need to keep them in a 
finished goods inventory and track their sales. 

Finally, you will be concerned with calculating the 
costs — labor, material and overhead. The production costs 
will help you decide your pricing policies anil determine 
your profitability. 



From this brief and simplistic overview ol a manufactur- 
ing operation it should be clear that there are many intricate 
relationships to deal with. Effective and efficient manage- 
ment of a manufacturing operation is difficult to achieve, 
and many neighborhood businesses as well as sophisti- 
cated manufacturing companies are turning to computers 
for help. 

Materials Management/3000 

Hewlett-Packard is among the vendors providing appli- 
cation systems for manufacturing managemenl— a man- 
ufacturing company offering a solution to the problems ot 
manufacturing companies. Materials Management. 3ui)U is 
an interactive material requirements planning and control 
system designed to make it easier to deal wilh the com- 
plexities ol operating a manufacturing company. II is 
primarily designed for manufacturers who build standard 
products to stock in discrete manufacturing steps | fab- 
ricators and assemblers). These companies have a signifi- 
cant investment in inventory. Materials Management 
3000 can help them balance their inventory levels with 
customer demands for timely shipments to optimize their 
dollar investments. 

The complexity of the manufacturing environment can 
also be seen in the internal complexity of the software 
product that provides solutions to manufacturing prob- 
lems. Materials Managemenl. 3001) consists of over 400,000 
lines of SPL* code which make up lbl transactions using 
nine data bases. There are 291 screens, both transaction 
screens and menu screens. There are also 188 batch pro- 
grams. The application data bases and screens can be cus- 
tomized by the user. Materials Management/3000 operates 
on any of the HP 3000 family of computers and uses the 
26XX family of terminals. The system uses HP's IMAGE data 
base management system and V/3000 screen handler. 

Materials Management/3000 consists of ten major mod- 
ules (see Fig. 1 ): 

■ Master Production Scheduling: MPS is an on-line man- 
agement planning and production scheduling tool. Il is 
used by the master scheduler to generate a production 
schedule lor the plant's marketable products and to set 
the mix lor the product options. Input to the module 
includes current customer orders, forecast customer or- 

•SPl i» !'\e MP 3000 Systems Piogiamming LdOQiiaou 
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Fig. 1. Materials Management! 
3000 consists of ten major mod- 
ules. It is primarily designed for 
manufacturers who build standard 
products m discrete manufactur- 
ing steps. 



ders, the current production schedule, and the current 
level of product inventory. The output of the MPS calcu- 
lations is called the master production schedule. This 
schedule contains suggested manufacturing orders in- 
cluding quantities and starting dates. The schedule is 
then input to the Materials Requirements Planning 
(MRP) module to plan the manufacture and purchase of 



the required component parts. MPS also includes a 
"'what if" simulation capability which allows the user to 
generate tentative schedules and view the impact of mod- 
ifications on the current schedule (F r ig. 2). 
Rough Cut Resource Planning: Rough Cut Resource 
Planning (RRP) is a management tool used by the master 
scheduler to help produce a realistic master schedule by 
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Fig. 2. This is a sample report 
from the Master Production 
Scheduling module. It compares 
product demand (actual and lore- 
cast orders) to the current produc- 
tion schedule (in units, dollars, and 
labor hours) The effect on inven- 
tory is noted The report also com- 
pares scheduled production to 
factory capacity and flags (OL) 
production periods that are over- 
loaded. Production schedules for 
individual parts can also be 
viewed on-line 
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Fig. 3. A sample report of the 
Rough Cut Resource Planning 
module This report compares the 
current scheduled production 
plan to the available production 
capacity 



comparing the resources needed to implement the master 
schedule with the available critical resources. The user 
specifies the critical resource requirements for each mas- 
ter schedule product and the maximum capacity of these 
resources. Examples of critical resources are labor hours, 
floor space, investment in work-in-process inventory, 
and material supplies. The RRP reports highlight the 
capacity constraints and help the user resolve competing 
demands for critical resources. An on-line RRP report can 
also be used to help evaluate simulated master schedules 
by comparing their resource requirements to the re- 
quirements of the current schedule [Fig. 3). 
Material Requirements Planning: MRP simulates the 
complex flow of materials required to manufacture prod- 
ucts and generates a material plan. MRP planning starts 
with up-to-date information about current inventory 
levels and the planned production requirements. Using 
part and bill-of-material information the material re- 
quirements for each part are calculated. The plan starts 
with the highest-level assemblies and proceeds through 
the lowest-level parts. MRP will reschedule current work 



and purchase orders and suggest new orders as necessary 
to meet the demand. MRP is a regenerative system; a 
complete material plan is generated every time MRP is 
run (Fig. 4). 

Parts and Bills of Material: This module provides on-line 
maintenance of engineering, accounting, and planning 
information about each part and product, and informa- 
tion on how the parts relate to one another to form the 
product structure (bill of material). Responsibility for 
maintaining this data will normally be shared among 
several departments — accounting, engineering specifi- 
cations, and planning. Part and structure data can be 
reviewed on-line or through printed reports. The part 
and structure data is used by many of the other modules 
in Materials Management/3000, including MPS and MRP 
(Fig. 5). 

Routings and Workcenters: The bill of material defines 
the parts and subassemblies that go into a product but 
doesn't document how the various components are as- 
sembled. The Routings and Workcenters module main- 
tains information that describes the locations where the 
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Fig. 4. A sample action report 
produced by the Material Re- 
quirements Planning module 
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Fig. 5. A sample on-line review of the bill ol material lor a part. 

products are made (workcenters) and the proper se- 
quence of manufacturing steps (routings). This informa- 
tion is used to generate cost information for the Standard 
Product Cost module, and to help develop detailed pro- 
duction schedules. Responsibility for this data usually 
resides with manufacturing specifications personnel. 

■ Standard Product Cost: SPC provides manufacturers 
with the capability of accurately calculating the standard 
costs associated with the manufacture of each product. 
All current cost information may be edited and reviewed 
on-line. The standard cost of a product is determined by 
accumulating all relevant material, labor, and overhead 
costs for the components of the product as well as the 
costs associated with the construction of the finished 
product. These standards can be used to determine prod- 
uct pricing and probability. Marketing personnel and 
the material manager use this data. 

■ Material Issues and Receipts: This module helps control 
stockroom inventory by maintaining timely and accurate 
records of all actions that affect inventory balances. The 
data includes receipts of work orders or purchase orders, 
material issues from stock to a particular work order, 
filling of a back order, or an unplanned issue. All record 
keeping and updating is done on-line and a record of all 
inventory activity is kept on-line for a user-specified 
period of time as an audit trail (Fig. (i). Stock room per- 
sonnel are the primary users of this system. 

■ Inventory Balance Management: The Inventory Balance 
Management module maintains information about in- 
ventory balances and the warehouse locations where the 
inventory is stored. The current inventory status can be 
affected by three types of transactions: material move- 
ment, inventory counts, and stock adjustments. All three 
types of transactions will trigger an immediate update of 
the inventory counts as well as create an audit trail rec- 
ord. All updates are done automatically in an on-line 
mode. Current inventory balance data from this module 
is used by MPS and MRP to determine the next master 
schedule and the next material plan. All activity that 
affects inventory status can be reviewed on-line. An in- 
ventory value report is also available. Materials 
Management 3000 also allows for multiple stock loca- 
tions; a separate on-hand balance can be maintained for 
each slock location in each warehouse. This system also 
helps with the counting of inventory, which is periodi- 
cally used to verify inventory totals. 
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■ Work Order Control: A work order is an internal factory 
authorization to build a specified quantity of a particular 
subassembly by a specified date. All work orders require 
the issue of on-hand inventory for their completion. Prior 
reservation of on-hand inventory is the best method of 
preventing shortages at the time of issue. Allocation, or 
logical reservation of on-hand inventory helps predict 
and prevent these shortages. The timely notification of 
exceptions to the material plan can allow corrective ac- 
tion before the results become disastrous. The outputs of 
this tracking system are reports noting exception condi- 
tions. The materials manager can act on these reports. 
The actual issuing of parts and work orders, and the 
actual receipt of finished products is accomplished using 
the Material Issues and Receipts module. MRP is a prime 
user of information from this system. 

■ Purchase Order Tracking: A purchase order represents a 
scheduled receipt for purchased items. Entering a pur- 
chase order requires the entry of more information than 
that required on a work order — for example, vendor in- 
formation, shipping information, and price information. 
It is also possible to group multiple delivery dates and/or 
multiple parts on the same purchase order. The Purchase 
Order Tracking module monitors these scheduled re- 
ceipts and maintains vendor information. Users can get a 
report on current orders for a particular vendor or the 
value of outstanding purchases by scheduled receipt 
date. The purchasing department and the materials man- 
ager normally use this module. 

What distinguishes Materials Management 3000 trom 
other materials management systems is not just its features 
but the design and implementation philosophy behind it. 
This philosophy evolved from previous experience with 
application systems, a knowledge of the competitive situa- 
tion, and first-hand experience with manufacturing com- 
pany operations. The design philosophy can be sum- 
marized as providing a functionally complete solution that 
fits the business practices of the user, is friendly and easy to 
use. and is supportable by IIP. As the philosophy evolved 
into more concrete design goals the project team realized 
that certain functional capabilities were required but were 
unavailable in the current set of tools provided on the HP 
3000. The team realized that it was not possible to antici- 
pate all the detailed and distinctive capabilities peculiar to 
any particular customer. The implementation strategy was 
to include standard and accepted functions in the program 
code and provide software tools to allow customers to tailor 
the system to fit their own requirements. The application 
designers thus precipitated the development of the required 
new tools, the Application Customizer and the Application 
Monitor described in the articles on pages 13 and 1!). 




Fig. 6. An on-line record ol inventory activity produced by the 
Material Issues and Receipts Module 
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Design Principles 

The development of Materials Management 3000 was 
guided by a set of design principles that can be grouped into 
four categories: contribution, simplicity, versatility, and 
supportability. 

Contribution. All product teams strive to meet HP corporate 
goals by producing products that are contributions in the 
marketplace and provide lasting value to the customer. 
Materials Management'3000 was designed to provide a con- 
tribution unusual in the industry — customizability with 
full vendor support. With other application system prod- 
ucts, customers must face the dilemma of accepting a stan- 
dard package and adjusting their business practices, or 
modifying the application source code to better suit their 
businesses and losing the support and enhancements avail- 
able from the vendor (or paying extra for it}, Materials 
Management. 3000 eliminates the need to choose between 
function and support. The user can customize the applica- 
tion system without jeopardizing the ability to get full sup- 
port from HP and to receive factory enhancements and 
upgrades. 

Simplicity. Materials Management 3000 embodies simple 
sophistication. The product provides a full set of functions, 
yet is friendly and easy to use. It represents a major step 
towards producing a manufacturing application system that 
requires no data processing staff and assumes the user has no 
knowledge of computers. 

The user interacts with the product using functional ter- 
minology, not computerese. Materials Management'3000 is 
menu-driven — the user simply selects the desired function 
from a list of choices. On-line help screens assist the novice 
user in stepping through the functions. I 'ser-oriented 
documentation, organized by lunctional area, is provided. 
Skilled users are not frustrated, however, since they can 
traverse the screen hierarchies at will simply by entering tin; 
name of the desired screen in the command window, a spe- 
cial input field lor control functions. They can even restruc- 
ture the entire screen sequence to better correspond to their 
operations. 

The application control functions are automated (e.g., in- 
itiating batch jobs). Instead of the MPE operating system, the 
user can interact with a monitor that is optimized lor nun- 
computer professionals. 

Supportability. A major design goal was to develop a prod- 
uct that could be tailored by the user and still be supported 
by IIP. This goal was achieved by separating the application 
code, which contains the standard product, from the 
parameters that characterize each particular instance of the 
application. The parameters are maintained in tables by the 
Application Customizes This design allows the user to 
alter the application without modifying the application 
code, All customers, then, have the same program code 
installed, so IIP has only one version of the product to 
support, regardless of how different each installation may 
appear. 

Versatility. Materials Management 3000 was designed to 
have functional generality. It can be tailored to fit each 
installation. Users can specify the parameters thai charac- 
terize their business practices, such as the order policy and 
the length of the planning horizon, and can specify the 
parameters thai Indicate how they will implement the com- 



puter solution: the terminal configuration, user passwords, 
and capabilities. Customers can also modify the face the 
application presents to the user. Field labels, screen names, 
screen contents, even the screen sequence can be modified, 
and the user can add fields to screens and data bases. The 
product is also versatile enough to allow customers to use 
the product as installed, without requiring customization. 
This versatility implies that the application will be easy to 
use for the novice, yet rich and sophisticated enough for the 
mature user. 

Implementation 

After determining the design goals for Materials 
Management'3000, the design team turned to the problem 
of implementing an application that would meet the criteria 
established during the design phase, yet would be efficient 
enough to provide good response time during heavy use. 
Some of the tools were already available. IMAGE/3000, the 
data-base subsystem, eliminates data redundancy and re- 
sulting maintenance problems. V 3000. the forms data entry 
subsystem, made it easy to design and implement a 
friendly, consistent user interface. The MPE message sys- 
tem provides a facility for creating customizable report 
headings and user error messages. 

To meet the ease-of-use objectives it was necessary to 
develop two more tools, the Application Customizer (page 
13) and the Application Monitor (page 19). The Customizer 
provides a method for the customer to tailor Materials 
Managemenl'3000 to fit an individual environment, and the 
Monitor automates many of the day-to-day administrative 
functions usually performed by an operations staff. The 
Monitor accomplishes its function by starling and stopping 
terminals at predetermined times and scheduling 
background jobs such as MRP to be run on a regular basis. 
System security is controllable because users may not use 
the application (i.e.. Materials Management/3000) unless 
the system administrator has instructed the Monitor tostart 
the application on a specific terminal. The Monitor also 
includes review capability of application-generated error 
messages and other system activity , such as the background 
job schedule or current terminal activity. To theapplication 
program, the Monitor provides many services normally as- 
sociated with operating systems. Theapplication programs 
may request services such as process initiation, inter- 
process communication, and resource allocation lor on-line 
terminals and printers. The application designer can con- 
centrate on solving application-oriented problems and call 
on the Monitor to provide other functions that are necessary 
but not directly involved with materials management func- 
tions. 

The key component of a customizable application is the 
application data dictionary, which serves as a repository for 
application-dependent information such as data item 
characteristics, data base schemas, V/3000 form descrip- 
tions, security passwords, terminal configurations and 
background job schedules. The Application Customizer 
was designed to maintain the data dictionary, and it per- 
forins two major functions. The first is a facility for custom- 
ers to alter or customize the application system using a 
simple menu-driven fill-in-the-blanks sequence of forms. 
Since this is the part of the Customizer most visible to the 
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customer, the bulk of the design effort went into making 
customization functions simple and easy to understand by 
non programmers. The second function performed by the 
Customizer is to transform the information present in the 
application data dictionary from data structures suitable for 
efficient on-line update to structures suitable for run-time 
access by the application programs. These transformed data 
structures, collectively known as the run-time application 
data dictionary, are used by the application programs to 
determine the values of all customizable parameters in the 
system. 

Fig. 7 shows how the Customizer. the Monitor, IMAGE' 
3000; V/3000 and the application software interact. 

Design Methods 

The rest of this article describes some of the methods used 
by the designers of Materials Management/3000 to design 
programs that can operate efficiently in a customizable 
environment. Because Materials Management/3000 is a cus- 
tomizable application, the customer has the ability to 
change many of the characteristics of the system by modify- 
ing items in the application data dictionary, rather than 
using the time-consuming and error-prone traditional 
method of modifying source code and compiling programs. 
Designing customizable applications is therefore compli- 
cated by the fact that many assumptions traditionally made 
by application programmers are not true. Customers may 
modify data item characteristics, add and delete items, 
modify the on-line user interface, and define additional 
processing. 

Changing Data Item Characteristics 

An assumption traditionally made is that once a data item 
is defined, its characteristics will not change. In a cus- 
tomizable environment that assumption is no longer valid. 
Because it is possible for the customer to alter the length, 
type and precision of any field, the application program has 
no idea what the characteristics of fields will be until the 
program is executing. For example, there are three broad 
categories of data type used by Materials Management' 
3000: alphanumeric strings, numeric fields, and date fields. 
An application designer may assume a data item is one of 



these three general types, but cannot know the specific 
format of the field. Numeric fields may be any of five 
numeric data types: display numeric (with explicit sign and 
decimal point), zoned numeric (with implicit decimal point 
and sign overpunchj, packed decimal, 16-bit integer, and 
32-bit integer. Any numeric field may be changed to any 
other numeric type and the length and the precision 
(number of decimal places) of display numeric, zoned 
numeric, and packed decimal numbers may also be altered 
by the customer. 

The solution is to place field definitions in tables that are 
accessed by the application program at execution time. 
These tables form the run-time application data dictionary 
generated by the Application Customizer and are accessed 
only by a set of Application Customizer routines called 
intrinsics. This enables the designer to code the application 
without specific knowledge of the structure of the tables. As 
the Application Customizer is enhanced, the tables may 
change, but the application programs will not have to be 
modified because the intrinsics insulate the application 
from the Application Customizer. 

A field may have several occurrences in an application, 
each having slightly different characteristics. For example, 
a numeric field may be present on an IMAGE data set. and 
also on a data entry screen defined for a transaction that 
updates the data set. The item on the screen will be defined 
as being display numeric type, with a length of ten digits 
including two decimal places. The same item on the data set 
will be defined as being packed decimal, with a length of 15 
digits including four decimal places. The designer can de- 
velop customizable programs without concentrating on 
these differences because of the intrinsics provided by the 
Application Customizer to handle all arithmetic and data 
movement operations. 

A table lookup is required every time any data item is 
manipulated by the application. .Materials Management/ 
3000 is structured to provide the best response time for 
users who perform the same transaction many times, using 
few or no other transactions. An example is loading dock 
personnel who perform "receive stock" transactions almost 
exclusively. When a transaction is entered, only that por- 
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Fig. 7. The designers of Materials 
Management/3000 used many 
services in designing transac- 
tions. VI3000 intrinsics (routines) 
communicate with the user termi- 
nal. IMAGEI3000 intrinsics store 
and retrieve data. Application 
Customizer intrinsics retrieve data 
item definitions, screen formats, 
data set formats, and customer- 
added processing specifications 
Customizer intrinsics also manipu- 
late any data items whose charac- 
teristics are unknown to the ap- 
plication designer and must 
be looked up in the Customizer 
tables 
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lion of the customizer tables that contains data item defini- 
tions used by the transaction is moved to the program data 
area. The data item definitions remain in memory until the 
user branches to another transaction. With the needed data 
item definitions in program data memory. Customizer in- 
trinsics may access data definitions with a minimum of 
overhead. This conserves memory and provides fast re- 
sponse time for subsequent executions. 

Since there are Customizer intrinsics that perform data 
movement and arithmetic operations, instead of coding 
SPL statements to manipulate data, the application de- 
signer codes calls to intrinsics that add. subtract, multiply, 
or divide numeric data items, and move numeric or al- 
phanumeric items. These intrinsics reference the data item 
definition tables, performing data validation, decimal point 
normalization, data type conversion, and security check- 
ing. If an error prevents proper processing, the intrinsic 
returns an appropriate error code, and the user can be 
informed. 

Modifying Fields 

In addition to changing data item characteristics, it is 
possible for the customer to add and delete some fields 
appearing on screens and data sets. Materials Manage- 
ment'3000 is designed to perform specific inventory control 
functions, so a working set of data items must be present far 
the application to perform its function properly. These data 
items are defined as critical to the application and may not 
be deleted by the customer. Other data items in the released 
product are included lor optional processing and may be 
deleted by the customer for reasons of efficiency or to pre- 
vent user confusion. On the other hand, a customer may 
want to adapt the application to perform additional func- 
tions not anticipated by the application designers. This will 
require the addition of data items to data entry screens and 
data sets. A method must be used to represent the associa- 
tion of data items with screens and data sets to the applica- 
tion programs. 

Fortunately, much of the processing in Materials Man- 
agement/3000 and many other data processing applications 
involves the movement of complete records from place to 
place. For example, "add" transactions simply construct a 
record from the data items entered on a data entry screen, 
and after appropriate validation edits, move the record to an 
IMAGE data set. "Change" transactions retrieve a record 
from a data set, update it with fields entered from the screen, 
and then move the record back to the data set. When 
adding or deleting a data item on a data set or screen both 
the designer and the customer must associate the item with 
a specific record format. Record formats are nothing more 
than collections of data item definitions that correspond to 
the fields on a data set or data entry screen record. A data 
entry screen record and the corresponding data set record it 
will update will contain many of the same data items, al- 
though they may have different characteristics. Since it is 
unknown until execution time exactly what items will be 
present on a given record, the Application Customizer pro- 
vides an intrinsic that moves corresponding data items 
from one record to another. 

The operation of the MOVE CORRESPONDING intrinsic is 
very simple. The intrinsic is passed the record format defi- 



nitions that describe the source and target records. For each 
item definition present in the source format, the intrinsic 
searches the target format for a corresponding item defini- 
tion. If a match occurs, the data is moved from the source to 
the target record, changing the data type, length, and preci- 
sion if necessary. This process continues until all corre- 
sponding fields have been moved from the source to the 
target record. The MOVE CORRESPONDING intrinsic allows 
the designer to think on a record level, not being concerned 
with individual data items. This makes it possible for the 
customer to add and delete noncritical data items at will. 
Fig. 8 shows an example of MOVE CORRESPONDING oper- 
ation, Each record is described by a format maintained by 
the Application Customizer. Every item is assigned a 
unique item number by the Customizer. This item number 
is used to identify all occurrences of an item. Each format 
consists of a format header, which contains pointers and 
information concerning other control structures, and a col- 
lection of item definitions, organized in ascending item- 
number order. The MOVE CORRESPONDING intrinsic per- 
forms its function for each item in the source format (in this 
case the screen format) which has a matching item defini- 
tion in the target format (the data set formatl. The intrinsic 
locates the field and determines its length, type, and preci- 
sion, using information stored in the item definition. In this 
example, the source field for item 135 is located at byte 0 
and is ten bytes long. An item type code of 3 indicates that 
the field is in display numeric format and the precision is 
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I wo decimal places. 

The target field is located at byte 54 of the data set record 
and is eight bytes in length. An item type code of 5 indicates 
that the field is in packed decimal format, and the precision 
is four decimal places. As shown at the bottom of Fig. 8. 
MOVE CORRESPONDING copies the field from the screen 
record to the data set record, changing the type, length, and 
precision of the data according to the item definition. 

Changing Screens 

In addition to changing field and record characteristics, 
the customer has the ability to modify the appearance of the 
application itself. Data entry screen appearance, and even 
the sequence of screens may be altered by the customer. 

V/3000 provides a relatively simple method for altering 
screen appearance. Screens may be redesigned by repaint- 
ing them using a few control character sequences on HP's 
26XX series terminals. This gives the customer the power to 
alter screens so they look like forms that are presently in 
use, lessening the technology shock that many users ex- 
perience. Screen alterations are then entered into the run- 
time application dictionary via the Customi/.er and trans- 
lated into updated record format definitions. The applica- 
tion program is thereby insulated from cosmetic changes to 
screens. The MOVE CORRESPONDING and other Customizer 
intrinsics handle changes in data field order as easily as 
additions and deletions. 

In Materials Management/3000, screens corresponding to 
transactions are at the bottom of a large tree of menus. The 
26XX terminal series has eight dynamically definable 
softkeys. These keys are used by the application as the 
primary method of moving from screen to screen. The top of 
each screen in Materials Management/3000 contains eight 
labels, each corresponding to a data entry screen or a menu. 
The user may navigate through the menu tree by pressing a 
soft key thai will cause the application to transfer to the 
desired transaction, or to a menu that will list seven other 
choices. The eighth function key is always labeled EXIT and 
takes the user to the screen's parent. 

The customer has the ability to modify these labels 
through the Customi/.er. creating subtrees for different 
users. For example, security reasons may require that a 
customer prevent stockroom personnel from altering any 
engineering data. By removing any labels that identify 
transactions dealing with engineering data, it is possible 
to restrict the stockroom personnel to a closed set of 
transactions. 

The application determines softkey definitions by look- 
ing up values in a screen sequence table, which is part of the 
run-time application dictionary and is accessed by Cus- 
tomizer intrinsics. An entry in the screen sequence table is 
associated with every screen. Before displaying a screen, 
the corresponding entry is moved to the program data area. 
If the user presses a softkey. the application looks up the 
value that corresponds to the key pressed and transfers 
control to the appropriate screen or menu. This allows the 
customer to be very flexible in tailoring the system and 
relieves the designer of the burden of determining the 
screen structure while coding. 

An additional feature becomes very powerful for experi- 
enced users of Materials Management'3000. A 16-character 



command window is present on all menu screens. If the 
function desired by the user is not directly accessible from a 
menu, the function name may be entered into the command 
window and the corresponding screen will be accessed 
directly, eliminating the need to navigate through the menu 
tree. Whenever the application detects an entry in the 
command window, a Customizer intrinsic retrieves the ap- 
propriate value, effectively providing a ninth softkey. 
which the application program is not aware of. The com- 
mand window may be altered via the customizer and 
V/3000 to accept only selected labels. This provides an 
additional measure of security, while providing the means 
for the experienced user to travel rapidly from screen to 
screen. 

Processing Logic Customization 

It is impossible for the designers of a general-purpose 
application to anticipate the needs of every customer. Cus- 
tomers will almost always want the application to do some 
additional processing, beyond the capabilities of the stan- 
dard product. With noncustomizable applications, the cus- 
tomer would either have to purchase source code and mod- 
ify it. or live with the standard product, Materials Manage- 
ment/3000 provides two methods of modification. The first 
involves V/3000 and the second involves the Application 
Customizer. V/3000 provides a set of powerful functions, 
including: checking for minimum length, data type checks, 
range checks, pattern checks, and data formatting. However 
these functions apply only to data entered on the screen 
records. To allow customer-defined manipulation and 
movement of data between screens and data sets, a set of 
functions called processing specifications may be entered 
using the Customizer. 

Processing specifications are defined by the customer for 
each transaction where additional processing is desired. 
Simple commands allow the user to add. subtract, multiply, 
divide, and move data items. These commands are com- 
piled and placed in tables that are accessed by Customizer 
intrinsics at execution time. In most of the product, each 
transaction is structured so that after all normal processing 
occurs but before any data sets are updated, the processing 
specification interpreter is called. This is a Customizer in- 
trinsic that performs the operations indicated by the 
customer-entered statements. It is possible to alter almost 
any data item on any data set that is to be updated by a 
transaction. This tool allows the customer to extend the 
usefulness of the application program to areas that were not 
originally anticipated by the designer. 

Fig. 9 shows how customer processing specifications are 
implemented. The format header of the screen format con- 
tains a pointer to any processing specifications the cus- 
tomer may have defined for the transaction. All processing 
specifications are generated by the Customizer and placed 
in a processing specification table, which resides in an extra 
data segment. The processing specification interpreter uses 
the pointer and length fields in the format header to locate 
and move the processing specifications defined for this 
transaction to the stack. The Customizer generates an in- 
termediate language in the form of triples, which consist of 
an operation code and two operands. Each operand field is 
either a constant, a register, or a formatfield number com- 
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Fig. 9. An example snowing how customer-specified proces- 
sing is implemented See text tor details 

bination. In this example, the customer wishes to convert 
the value entered in field 135 from pounds to grams and 
accumulate the result in field 222, which is described in 
format 14. This might occur in the situation where the 
customer wishes to record the year-to-date quantity ordered 
for management reporting. Field 135. described in format 
22. corresponds to the quantity-ordered field on the data 
entry screen. Field 222. described in format 14. corresponds 
to the year-to-date quantity ordered, which is accumulated 
on some other record for use in preparing periodic man- 
agement reports. The normal unit of measure for ordering is 
pounds, but lor some reason, management has decided to 
accumulate the total quantity in grams. The first triple 
moves the constant 454 to register t. The second triple 
multiplies the contents of fieltl 1 35 by the contents of regis- 
ter Land places the result back in the register. This converts 
the value ol the field from pounds to grams. The contents of 
the register are then added to the contents of field 222 in the 
third triple. Upon returning from the processing specifica- 
tion interpreter, the transaction will update all of the af- 
fected data sets. This method of implementation allows the 
customer to add to or override the processing specified by 
the application designers. 

Local Languages 

HP's market for manufacturing applications is 
worldwide. The application designer cannot assume that 
the users of an application understand the English lan- 
guage. Materials Management'3000 is designed to be com- 
pletely localized to any language supported by the 26XX 
series terminal without reprogramming. Localization may 
be accomplished by translating the screens using V/3000, 
by modifying report headings and error messages stored in 
message catalogs, and modifying other literals maintained 
in the application data dictionary. Materials Management; 
3000 uses many single-word literals to control processing. 



For example, a user may enter engineering information 
about a pari, such as whether it is normally purchased or 
fabricated. The English version of Materials Management 
3000 codes this information as P or F on the data base. The 
literals P and K will have different interpretations in other 
languages. Therefore the custoraizer maintains another 
table containing all literals defined by the application de- 
signer When manipulating literals entered by users, the 
application must first look up the current value of the lit- 
eral. The table is loaded into the program data area and 
accessed by Application Customizer intrinsics. Because the 
table is located in the program data area and accessed di- 
rectly, there is very little additional overhead. Non- 
English-speaking customers have an application product 
that is easily understandable by their users, and the support 
burden is minimized for HP because only one version of an 
application system needs to be supported instead of one for 
each language. 

Security Checking 

An advantage of manipulating data in an interpretive 
mode is that other functions may be added with a minimum 
of effort by the designer. One example is security checking. 
Many auditors demand that security access be carried down 
to the data item level. In Materials Management 3000. each 
user is assigned a password that will grant that user access 
to only the data items that he or she is expected to review or 
update. The password is entered only once on a special 
security screen. The user may view only screens that con- 
tain data items for which that individual has access, and on 
screens that may be accessed, not all data items may be 
reviewed or updated. This allows the user to see and ma- 
nipulate only the authorized items. 

This type of security would require a lot of design and 
coding effort in a conventional system. In Materials Man- 
agement'3000 the Customizer intrinsics that manipulate 
data also perform a security check. The Customizer main- 
tains a table containing all valid passwords along with a list 
of data items to which that password grants access. Each 
time a Customizer intrinsic accesses a data item, a table 
lookup is performed. If the user does not have access to the 
item, an error message is displayed on the terminal. This 
powerful feature is implemented with a minimum of over- 
head and design effort. 

Conclusion 

Materials Management/3000 is HP's first user-customiz- 
able, factory-supportable application system. It is a tool 
developed to help manufacturing management plan and 
control material requirements and inventory levels. The 
product may be tailored by the customer to fit individual 
Circumstances without modifying source code. The Appli- 
cation Customizer, used by application designers and cus- 
tomers, allows extensive data item and cosmetic customiza- 
tion. The Application Monitor handles many day-to-day 
operating functions traditionally performed by an opera- 
tions .staff, making the design and use of Materials Man- 
SgBBient/3000 easier. Built on the Customizer and Moni- 
tor, Materials Management .'11)00 is another step toward 
providing a total solution for manufacturing companies. 
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REFERENCE INFORMATION 

HP Model 32260A Materials Management/3000 
Manufacturing Systems 

Materials Management 3000 is a user customizable, interactive system lor managing trie 
materials planning and control (unction of a manufacturing operation Materials Management 
3000 consists of ten application software modules 

• Master Production Scheduling 

• Rough Cut Resource Planning 

• Pans and Bills of Material 

• Routings and Workcontors 

• Material Issues and Receipts 

• Inventory Balance Management 

• Work Order Control 

■ Purchase Order Tracking 

• Material Requirements Planning 

• Standard Product Costing 

A discrete manufacturer who assembles standard, multi-piece products in lots represents the 
ideal candidate tor Materials Management 3000 However, the software is applicable to 
most manufactunng operations. Hewlett-Packard Sales Representatives and Manufactur- 
ing Industry Specialists are available tor consultation regarding the suitability of Materials 
Management 3000 lor a specific application 

Materials Management 3000 is available in a form which meets the input, output, and pro- 
cessing requirements of most manufacturing companies Manufacturing personnel may, 
however, modify data entry screens, data edits, and information retneval screens to suit 
their specific needs. They may also add. delete, and or modify data items in the Materials 
Management 3000 data base All of these changes can be accomplished easily and wttnout 
the need lor computer programming 

Materials Management 3000 is a standard (object codei application product which is fully 
supported by Hewlett-Packard A comprehensive support package is available and includes* 

■ 1 1 user reference and installation manuals 

• 2 weeks of customer training 

■ Planning, implementation, and customization consulting by Hewlett-Packard manufactur- 
ing industry specialists. 

■ A wide range of software support services. 
FEATURES 

■ On-line IMAGE data base update 

■ Customizable user interface and data base. 

■ On-lme terminal data entry, field editing, and error correction using the capabilities of 
HP s Data Entry and Forms Management System, V.'30O0. 

■ Easy to use. on-line transaction menus 
« Automatic transaction logging 

■ Taiiorable data entry screens and retnevats 

• On-line assistance via help screens. 

• Use of intelligent HP CRT terminals 

• Predefined materials data base 

• Use of proven matenals management techniques 

• Advanced secunty capabilities 

• Automated operator functions 
HARDWARE ENVIRONMENT 

For Materials Management 3000, the minimum system recommended is an HP 3000 Series 
44. Ill, 33. or 30 with 512K bytes ol memory However, the amount ol memory actually 
needed will depend on expectations regarding terminal response time and transaction volume. 
A minimum of tOOM bytes ot disc storage is required, in any specific situation the enact 
amount ot disc storage will be determined by an HP manufactunng industry specialist 
The interactive terminals must be HP26XX series CRT units with at least 4K bytes of terminal 
memory (8K bytes is recommender'l Display enhancements are also recommended 
SOFTWARE ENVIRONMENT 

Materials Management 3000 requires the HP 3000 Computer System Fundamental 
Operating Software 
ORDERING INFORMATION 

Product Number Description Price in U.S.A. 

32260A Righi to use Matenals Management 3000 531 ,500 

Includes one complete manual set 

32250R Right to copy and sublicense one Materials Manage- S26.250 

menl3000 Includes one complete manual set 

32260M Right to copy one Materials Management S10.500 

3000 without sublicense Includes one 

complete manual set 

MANUFACTURING DIVISION: MANUFACTURING SYSTEMS OPERATION 
19447 Prunendge Avenue 
Cupertino. California 95014 U S A 
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A Novel Approach to Computer 
Application System Design and 
Implementation 



by Loretta E. Winston 



TRADITIONALLY. BUSINESSES wanting to com- 
puterize their operations have been faced with two 
alternatives: develop an in-house solution using 
their own programming resources or purchase a standard- 
ized solution from an OEM or independent software 
house. Both alternatives have serious drawbacks. The 
development and continuing maintenance and enhance- 
ment of in-house application systems are expensive and 
very time-consuming. Furthermore, the initial time re- 
quired to develop an in-house system delays the realiza- 
tion of any benefits from a computerized solution. Pur- 
chased software systems, on the other hand, are for the 
most part relatively inflexible. Businesses must either 
adapt their operations to fit the specifications of these pre- 
defined solutions or undertake the costly programming 
required to achieve a satisfactory solution. If they choose 
the latter course, they risk losing the support of the sys- 
tem vendor. 

Hewlett-Packard's Application Customizer and Applica- 
tion Monitor, new software systems for the HP 3000 Com- 
puter, offer users a third alternative. These systems allow 
application designers to construct generalized application 
solutions and provide users with tools to tailorapplications 
to meet existing needs and to modify these applications to 
meet the ever-changing requirements of business. These 
systems also provide tools for the user to define, initiate, 
and control an entire application system. All of this may be 
accomplished by personnel who are not data processing 
(DP) professionals. 

This major contribution to application system design and 
implementation drastically reduces the need lor businesses 
to maintain a large staff of DP professionals to supervise 
in-house computerized applications. 

The first HP software product to make use of the Applica- 



tion Customizer and the Application Monitor is Materials 
Management.3000, a comprehensive materials planning 
and control system for manufacturers (see page 3), The 
entire application consists of the Application Monitor, the 
Application Customizer. and a set of customizable applica- 
tion systems. Fig. 1 illustrates the relationship between the 
various components. The Application Customizer and Ap- 
plication Monitor are basically tools to support the applica- 
tion software systems. Neither the Application Customizer 
nor the Application Monitor is itself customizable. This 
article describes the Application Customizer. The Applica- 
tion Monitor is described in the article on page 19. 

Customization Capabilities 

The Application Customizer offers an unconventional 
approach to constructing tailored application solutions. It 
is a compromise between the traditional approach — 
supplying source code application packages to end users 
and allowing them to reprogram these solutions using a 
general-purpose programming language to meet their 
specific requirements — and providing users with a 
specialized applications language to develop their own 
customized application systems. 

Customizable application systems are table-driven so 
that the costly programming and debugging efforts nor- 
mally associated with implementing tailored application 
solutions are eliminated. For each application the Applica- 
tion Customizer maintains a set of tables that define the 
application and its operational environment. These tables 
are collectively referred to as the application data dictio- 
nary. Tailoring of the application system is accomplished 
by modifying these underlying tables; no source program 
code is ever modified. 

The application data dictionary differs from conven- 
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Fig. 1. The structure ol a cus- 
tomizable application system, 
such as Materials Management/ 
3000, based on the Application 
Customizer and the Application 
Monitor, 
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lional data dictionaries in several respects. Conventional 
data dictionaries are basically repositories of information 
about the data bank, containing information such as data 
item names and characteristics, alias definitions, security 
specifications, edit information, and relationships between 
data items (i.e.. data structures). The application data dic- 
tionary contains information not only about the data bank, 
but about the application system as well, including applica- 
tion data structures such as screen and report layouts, in- 
ternal data structures, and application configuration. In 
traditional dictionary-based applications, if I he characteris- 
tics of an existing data item are changed, or a new data item 
is added, or an existing data item is deleted, all programs 
that use the data item must be changed also. In Application 
Customizer dictionary-based systems, no reprogramming is 
necessary. Further, most data dictionary systems are pas- 
sive in nature. They basically serve as documentation 
facilities and are unaware of the data base management 
systems and application processes that operate within the 
same overall environment. Information in the application 
data dictionary, on the other hand, is used during the actual 
execution of application programs. 

There are two classes of Application Customizer users: 
application designers, who develop customizable applica- 
tion solutions, and system administrators, who tailor these 
generalized application solutions to meet the specific needs 
of their business environments. System administrators are 
roughly equivalent to systems analysts in terms of comput- 
er problem-solving skills and expertise. They are not neces- 
sarily computer programmers. System administrators have 
the responsibility not only for customizing application sys- 



Fig. 2. A summary of the customi- 
zation features provided by the 
Application Customizer 

terns but for supervising and controlling the daily operation 
of these application systems as well. Fig. 2 summarizes the 
capabilities provided by the Application Customizer. The 
entire set of customizable capabilities is available to appli- 
cation designers. Only a subset of these capabilities is avail- 
able to system administrators. 

Generally when we speak of the Application Customizer, 
we mean the user interface to the Application Customizer 
system, which is an on-line, interactive program. However, 
the entire Application Customizer system consists of three 
major components: the user interface component, a set of 
routines (called intrinsics) that perform data conversions, 
computations and comparisons on customizable data fields 
and data structures, and a program that prepares a run-time 
(object) version of the application data dictionary from the 
compile-time (source) data dictionary (see Fig. 3). Two ver- 
sions of the application data dictionary are maintained to 
allow one class of users to customize the application sys- 
tems at the same time that a second class of users is operat- 
ing or executing these applications. 

The next section of this article outlines the steps an appli- 
cation designer takes in implementing a customizable ap- 
plication system and the final section illustrates the steps a 
system administrator might take in tailoring a customizable 
application system to fit specific needs and requirements. 

Implementing a Customizable Application System 

An application subsystem is a logical grouping of on-line 
and interactive transactions, background jobs, and reports 
that provide a total solution to some well-defined user prob- 
lem or task. An application system is a group of one or more 
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Fig. 3. The Application Cusiomizer consisfs ol three ma/or components 1) the user interlace 
program, 2) a set ol routines that perform data conversions, computations, ano comparisons 
on customizable data lields and structures, and 3) a run-time application data dictionary 

preparation program 



interrelated and interdependent application subsystems. 
There are two major tasks involved in implementing a cus- 
tomizable application system: 1 ) defining the overall appli- 
cation and its operational environment and 2) specifying 
the application data bank and set of functions that make up 
each application subsystem. These two tasks are further 
divided into several subtasks. To define the overall applica- 
tion and its environment requires the specification of the 
following entities: the application system, application sub- 
systems, device and terminal configuration, and terminal 
security configuration. The complete specification ot the 
application subsystems involves the actual coding of the 
transactions, background jobs, and reports, the definition ot 
application data bases, and the specification of user inter- 
faces for the various application functions (e.g.. user mes- 
sages, screen and report layouts). 

To illustrate the steps involved in developing a cus- 
tomizable application system, the implementation of a 
hypothetical Inventory Management System will be pre- 
sented. The Inventory Management System consists of a 
number of subsystems, one of which is the Inventory Stock 
Status Subsystem. This subsystem consists of transactions 
to adjust inventory balances, receive and disburse goods 
from inventory, transfer stock from one location to another, 
return goods to inventory, review stock status, and indicate 
recent stock activities. The Inventory Stock Status Subsys- 
tem provides a report called the Inventory Count Analysis 
Report that lists the current inventory status for all 
warehouses and inventory locations. This report is gener- 
ated by a background job that is scheduled for execution on 
a demand basis. The subsystem contains a data base that 
consists of two major data sets called Stock Activity and 
Inventory Master. The Stock Activity data set contains basi- 
cally an audit trail of transactions against inventory. The 
Inventory Master data set contains stock information by- 
warehouses and Inventory/bin locations within these 
warehouses. In defining the application and its operational 
environment, the first step is to define the name and charac- 
teristics of the application system as illustrated in Fig. 4. 
Second, the names and characteristics of the application 
subsystems are specified. Fig. 5 shows one of the subsys- 



tems, namely Inventory Stock Status, being defined. Third, 
terminals for operating the application subsystems are 
specified, and finally, passwords to access these terminals 
are specified. This completes the specification of the appli- 
cation and its operational environment. The next major task 
is to define the data bases, functions and interfaces for each 
of the application subsystems. Figs. 6 and 7 show two steps 
in the definition of the application data bank. Figs. 8 and 9 
illustrate typical steps involved in adding a new transaction 
to an application subsystem. The pseudo-code for the new 
transaction called "Adjust Quantity on Hand" is given be- 
low: 



Step 1 
Step 2 
Step 3 



Step 4 



Step 5. 

Step 6. 

Step 7. 

Step 8. 

Step 9. 

Step 10. 

Step 11. 



Read user-entered input from screen, 

Lock INVENTORY MASTER data set. 

Read INVENTORY MASTER record for 

specified PART— NUMBER, WAREHOUSE and 

INVENTORY—LOCATION. 

Add ADJUSTMENT—QUANTITY to 

QUANTITY ON HAND. 

Update INVENTORY MASTER record. 

Unlock INVENTORY MASTER data set. 

Move corresponding fields from input screen 

buffer to STOCK ACTIVITY record buffer. 

Lock STOCK_ACTIVITY data set. 

Add record to STOCK—ACTIVITY data set. 

Unlock STOCK— ACTIVITY data set. 

Exit. 



m 



Fig. 4. An Application Customizer screen lor specifying a new 
application system 
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Fig. 5. An Application Customizer screen for defining a new 
application subsystem 

Fig. 8 shows segments of this program written in the HP 
3000 Systems Programming Language. SPL3000. The seg- 
ments shown correspond to steps 4 and 7. respectively, in 
the pseudo-code program. The major coding difference be- 
tween this and a conventional approach is that data ma- 
nipulations (data transfers, conversions, comparisons, and 
arithmetic/logical operations) are not hard-coded; rather 
they are performed via specialized Application Customizer 
routines (intrinsics). To illustrate the power and usefulness 
of this feature, consider the following example. Suppose 
that transaction X adds records to data set Y and further 
suppose that a user wants to add a new field /. to data set Y 
and initialize it via transaction X. To accomplish this in 
customizable application systems, the user simply adds the 
new field '/. to both data set Y and the screen for transaction 
X. The data handling routines will automatically move this 
new field from the screen to the data set. No reprogramming 
is necessary. 

To better understand how this works, the contents of the 
application data dictionary must be examined in greater 
detail. The Application Customizer maintains a description 
of every application structure in its data dictionary. An 
application structure is a general term used to describe any 
collection of related fields. These include application 
screens, reports, data sets, and internal structures. For each 
application structure the Application Customizer main- 
tains a format that contains the set of fields in the structure, 
their data types, their lengths, and other pertinent informa- 
tion. The application designer defines the default set of 
application fields and application structures. End users 
may add and delete field specifications from the entire 
application, add and delete fields from specific application 
structures, and change the lengths and data types of fields 
within application structures. Hence, specialized data ma- 
nipulation and arithmetic logical routines are provided 
to accommodate the customization of these application 
structures. 

Basically, arithmetic/logical routines work as follows. In- 
formation on the data types and lengths of the source and 



Fig. 6. An Application Customizer screen tor defining a new 
application data Case 



Fig. 7. An Application Customizer screen for defining a new 
application data set. 

destination fields is retrieved from the application data 
dictionary. The source fields are converted to an appro- 
priate intermediate data format. The arithmetic operation is 
then performed. Finally the result of the computation is 
converted to the appropriate output data type and stored in 
the destination field. The other operations work similarly. 

To complete the specifications of the Adjust Quantity on 
Hand transaction described above, the user interface must 
be designed and user messages entered. Fig. 9 illustrates the 
definition of a new form. A general-purpose screen-design; 
forms-management facility. V/30U0. is provided for paint- 
ing screens. At present there is no automated mechanism 
for creating screen formats for the application data dictio- 
nary from screens designed using the forms management 
facility. This must be done manually. However, automation 
of this step is anticipated in a future release of the product. 

Customization of Processing Logic 

Customization capabilities may be divided into four logi- 
cal categories: application specification, user interface, ap- 
plication structures, and processing logic. Examples of 
three of these general capabilities have been demonstrated. 
The fourth capability, processing logic customization, is 
briefly described below and an example is given in the 
next section. 

Customization of processing logic allows end users to 
tailor the functioning of application procedures. There are 
three different mechanisms for customizing processing 
logic: by selecting an algorithm from among a predefined 
set of algorithmic choices or techniques, by specifying a 
customizable parameter value, and by adding new process- 

<< INCREHEMT QUANTITY ON HAND Br ADJUSTMENT QUANTITY >> 
AC 'ADD • FORMAT 'ADJUST'QTv'ON'HAND, 

FIELD' ADJUSTMENT' OTY, 

BUFFER' ADJUST' OTY' ON' HAND, 

FORMAT " I NVENTORY ' MSTP , 

FIELD' OTV ON 'HAND. 

B'JF F £ R • I N VE NTO Rl ' * MS TR . 

FORMAT' I NVENTORVMSTR, 

F I EL D ' OTV ' ON' HAND , 

BUFFER ' I NVENTOR 1 ' MSTP , 

AC * STATUS 1 i 



C< MOVE CORRESPONDING FIELDS from THE DATA ENTRY 

SCREEN BUFFER TO THE STOCK-ACTIVITY RECORD BUFFER H 
AC'MOVE'CORP I FORMAT ' AD J US T' OTY' ON' HAND, 

BUFFER' ADJUST' QTY'ON' HAND. 

FORMAT-STOCK 'ACTIVITY, 

BUFFER' STOCK 'ACTIVITY, 

AC'STATUSI; 



Fig. 8. Program segments from a customizable application 
transaction, showing calls to Application Customizer rou- 
tines (intrinsics). e.g. AC ADD. 
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Fig. 9. Designing a V 3000 screen tor a new transaction 

ing steps. The first two mechanisms must be provided for by 
the application designer in coding the application func- 
tions. In instances where there are several recognized 
techniques employed by businesses, the application de- 
signer may elect to make all techniques available and allow 
the system administrator to select the particular technique 
or algorithm to be used. The concept of customizable 
parameter values is a slight variation of this same principle. 
In this case a single method for performing an application 
function is provided, but the input parameter(s) to the func- 
tion may be changed dynamically by the system adminis- 
trator. The third mechanism is by far the most powerful. It 
allows the system administrator to add special processing 
steps to existing application functions. 
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Fig. 10. An Application Customizer screen tor defining a new 
data item. 
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Fig. 12. Changing a function key label on a screen torm 
tV 3000 screen) 

Tailoring an Application System 

The following case study illustrates the ease with which 
an application may be tailored, without programming, to 
meet the requirements of a particular environment. Using 
the hypothetical Inventory Stock Status Subsystem de- 
scribed previously, several examples of customization are 
presentetl. 

A clear distinction is made between customizing the ap- 
plication data dictionary and activating those changes. A 
special background job that prepares a run-time version of 
the application data dictionary is executed whenever cus- 
tomization changes are to be made available to the applica- 
tion subsystems. This allows application operators or data 
entry clerks to operate the application subsystems at the 
same time that the system administrator is customizing 
these subsystems. 

The first example illustrates the simple steps necessary to 
add a field to the application. 

Problem Statement. A user wants to keep track of the name 
of the warehouse foreman whenever an adjustment of in- 
ventory at a location is made. 

Solution. The first step is to define the new data item to the 
application dictionary as shown in Fig. 10. The second step 
is to add the new field to the appropriate form or screen via 
the screen-design/forms-management system and then re- 
compile the forms file. The third step is to add the new field 
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Fig. 11. Application Customizer screens illustrating how new 
processing steps are added to a transaction. 



Fig. 13. Changing a function key detmition in the application 
data dictionary (Application Customizer screens) 
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Fig. 14. Customizing user messages 

to the application data dictionary's screen layout, and the 
fourth step is to add the new field to the data base. The final 
step after customization is complete is to make the revised 
transaction available to application operators. This is ac- 
complished by executing the background job thai prepares 
the application data dictionary. 

The second example illustrates the ease with which spe- 
cial calculations may be added to an existing Iransaction. 
Problem Statement. A user wants to display the percent- 
age of the adjustment whenever the inventory balance 
is adjusted. 

Solution. The customization changes required are very 
similar to those outlined in the previous example and may 
be entered at the same time. In addition, special processing 
steps to calculate the percentage adjustment must be added 
to the application data dictionary for this transaction. Two 
steps are illustrated in Fig. 11. 

The next example demonstrates the ease with which 
function key definition may be changed to access different 
application functions from a particular transaction screen. 
Problem Statement. A user wants to be able to access the 
"Review Inventory Activity" menu screen from the "Adjust 
Quantity at an Inventory Location" screen. 
Solution. The first step is to modify the function key label 
on the form or screen via the screen-design/forms- 
management facility and to recompile the forms file. The 
next step is to change the function key definition for this 
transaction screen in the application data dictionary. This 
two-step process is shown in Figs. 12 and 13. 



The fourth example demonstrates the ease with which 
user messages may be customized. 

Problem Statement. A user wants to change the error mes- 
sage that is displayed when an invalid warehouse or inven- 
tory location is entered. 

Solution. The user simply invokes the editor system from 
the Application Customizer, modifies the message as de- 
sired, and then activates those changes. Fig. 14 shows the 
error message before and after customization. 

The final example illustrates the simple steps necessary 
to change the schedule for a background job. 
Problem Statement. A user wants to schedule the Inventory 
Count Analysis Report job to be executed automatically on a 
weekly basis rather than on demand. 
Solution. As shown in Fig. 15. the user simply makes the 
necessary changes to the application data dictionary's 
schedule for this background job and then activates those 
changes. 

Conclusion 

Customizable application systems offer customers the 
best of both worlds. They make it easy for users to construct 
tailored application systems without costly and time- 
consuming programming, debugging, and maintenance ef- 
forts, and they permit on-going vendor support of these 
tailored systems. The HP 3000 Application Customizer 
provides many tangible benefits to application designers as 
well. It provides specialized routines and utilities that 
facilitate the implementation of customizable application 
systems and enhance maintainability and supportabilit v. 
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Automating Application System 
Operation and Control 

by Barry D. Kurtz 



APPLICATION SYSTEM OPERATION and control 
means the daily use and supervision of application 
system functions, including initiating programs 
that provide application functions to the user and schedul- 
ing and monitoring background jobs performing batch 
processing. 

Until now. application system operation and control have 
required considerable user intervention. Also, since most 
business computing machines are general-purpose in na- 
ture, the task of initiating application programs is fre- 
quently left to personnel who are not computer profession- 
als. Thus the user of an application (a clerk, receiving dock 
worker, etc.) may have to learn the host machine's com- 
mand language and error codes, which are optimized for 
general machine use instead of individual applications. 

Recent developments in operating system software have 
lessened the burden on the non-computer professional. 
These include user-defined commands, comprehensive 
"help" facilities, and so on. However, these have solved 
only part of the implementation problem. The user should 
perceive the computer system as a comprehensive solution 
to an application problem and not as a set of unrelated 
application tools. 

Hewlett-Packard is dedicated to increasing the ease of use 
of application systems. A project that has made a great 
contribution to the ease of control and operation of applica- 
tion systems is called the Application Monitor, and was 
developed as a component of the current Materials 
Management:*!)!)!) application system offered by IIP |see 
page 3). The Application Customizer described in the pre- 
ceding article is another part of this effort. 

The Application Monitor controls the execution of appli- 
cations running under its control and provides services to 
them. It schedules, initiates and controls all inleractiveand 
background job activities in an application system. A 
friendly lill-in-the-form CRT interface is used by the user or 
manager of the system to review and control system activ- 
ity. The monitor takes a major step toward operatorless. 



abortless application systems by providing automatic ap- 
plication scheduling, control, and recovery services. 

User Interface 

The user interface of the Application Monitor, a friendly 
fill-in-the-form CRT interface, allows the user or manager of 
the system to perform comprehensive system control with- 
out having to learn a complex command language. Each 
screen presented uses the special function keys of HP 26XX 
series CRT terminals. The functions are described in eight 
shaded boxes at the top of the screen. Each box corresponds 
to a single function key (softkey). 

A command window is also presented on Monitor menu 
selection screens. This area is used for special system con- 
trol functions that are not executed by a simple function 
key signal. 

Since the functions made available through the user in- 
terface are critical to system operation, the user may not 
add, delete, or change Application Monitor screens. 

Traditional Application System Activities 

Most application systems involve the following ac- 
tivities: 

■ Initiating on-line applications on user terminals 

■ Scheduling and monitoring background job processing 

■ Running recovery and cleanup jobs 

■ Supervising system operation. 

Traditionally, most of these activities were executed 
manually and required frequent human intervention. All 
control was dependent upon the attention of the operator. 
This practice has led to inconsistent data processing ac- 
tivities, sometimes resulting in the loss of critical manage- 
ment reports. 

The Monitor allows the user or manager of an application 
system to automate all of the above activities, thus provid- 
ing an environment in which consistent data processing 
may take place. This reduces the frequency and severity of 
errors and security breaches, and reduces the training re- 
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Fig. 1. The application system 
environment, showing the rela- 
tionship ol the Application Monitor 
to other programs The Applica- 
tion Monitor initiates, monitors, 
and controls run-time application 
activities Monitor services are 
provided to application programs 
and users to initiate additional 
processes and supervise system 
activity The Application Cus- 
tomizer may be initiated to alter the 
tables that define the system envi- 
ronment 
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Fig. 2. The Sysfem Administrator Interlace is the system ad- 
ministrator's window to the application system The functions 
that may be initiated Irom this screen are represented in eight 
shaded boxes at the top ol the screen These functions are 
initiated by pressing one of eight terminal function keys. This 
relieves the system administrator of the need to memorize a 
system command language, and allows functions to be in- 
itiated quickly and accurately. 

quired for administration of the application system. 

Classes of Application System Users 

Two main classes of users make use of the services pro- 
vided by the Monitor: system administrators and end users. 
The system administrator is an individual who has global 
responsibility for the application system. This individual 
supervises and controls all application system activities 
(i.e., background job scheduling, on-line application 
scheduling and control, etc.). 

The end users of an application system include all those 
who use application program functions (i.e.. clerks, manag- 
ers, receiving dock personnel, stores or inventory person- 
nel, etc.). End users benefit from good application system 
management, which leads to consistent data processing, 
reports that are on time, and other benefits. However, ihey 
do not usually get involved in actual operation and control. 

Application System Operational Environment 

The Application Monitor consists of eight separate pro- 
grams. These programs run simultaneously and work to- 
gether to monitor and control the application system. Fig. 1 
depicts the application system environment. 
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Fig. 4. The Processing Schedule Maintenance user interface. 
The Processing Schedule Maintenance process allows the 
system administrator to review the background /ob schedule 
for the current day In this example, three jobs are scheduled 
to be run The first yob (SUMMARIZED BILL) has its AUTO START 
flag set to N. This means that it will require manual intervention 
to run The system administrator must set the tlag to Y betore 
the scheduled run time. The other jobs will run automatically 
when their run time comes up 

The following is a brief description of the major processes 
that make up the Application Monitor. 
Monitor Control Process (MCP). The Monitor Control Pro- 
cess is the parent of all programs in the application system 
environment. Once the application system is active, it is 
this program that initiates, monitors and controls applica- 
tion program activities. 

The MCP uses a memory table to track program activity 
throughout the system. This table is called the application 
control table (ACT) and is constructed during system in- 
itialization. Each program in the system has an entry in this 
table called a process informalion block. The information 
kept in each block is sufficient for the MCP to monitor the 
current status of each program and provide any services 
that are determined necessary. 

System Initialization Process (SIP). The system initializa- 
tion process is initiated al system startup time and executes 
once a day. This program reads a prepared application data 
dictionary generated by the Application Customizer (see 
article, page 13). Based on the information read from this 
dictionary, the SIP initializes global tables to be used by the 
application system. 

System Administrator Interface (SAI). This program is the 
system administrator's window to the Application Monitor. 
The SAI allows the user to select various functions to review 
and control application system operation. Fig. 2 depicts the 
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Fig. 3. The System Activity Process user interface The Sys- 
tem Activity Process allows the system administrator to review 
current system activity. Interactive application transactions 
may be tracked and background /ob execution may be con- 
trolled, in this example. SOS'S terminal is executing the re- 
view part transaction (ten transactions have been executed, 
and the terminal has been active since 8 02 AM.) A 
background fob (daily REPORT) is running and is presently 
executing the SORT INPUT step. 
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Fig. 5. The Processing Schedule Maintenance process al- 
lows the system administrator to modify the background /ob 
schedule. In this example, a job /part reports) is being 
added to the schedule If this job is to be run at regular 
intervals, the system administrator may modify the permanent 
lob schedule in the application data dictionary via the Cus- 
tomizer The job will then automatically be scheduled to run 
daily, weekly, monthly, or yearly as specified. 
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Rg. 6. The System Messages Process User interface The 
System Messages Process allows review of system /oforma- 
tional messages ana messages requiring action from me sys- 
tem administrator. In this example, a background job has been 
restarted and has tailed on the restart. The Background Job 
Processor is asking the system administrator if the job should 
run agam The system administrator may initiate the reply 
action to this message by pressing the appropriate terminal 
function key corresponding to a shaded box at the top o! the 
screen 

user interface for the system administrator process. 
Job Scheduler Process (ISP). The job scheduler process 
automatically schedules background jobs that were speci- 
fied to be run on the current day. These jobs are predefined 
by the system administrator through the Customizes 
Background Job Processor (BTP). A background job that has 
been scheduled for execution will be processed by the 
background job processor. This program executes 
background job commands and provides comprehensive 
job restart and recovery capability. 

System Activity Process (SAP). This program allows the 
system administrator to review and control system ac- 
tivities. Through the SAP user interface the system ad- 
ministrator can review the current activity of all interactive 
and background job processes and control background job 
processing concurrency. Fig. 3 depicts the system activity 
user interface. 

Processing Schedule Maintenance (PSM). The processing 
schedule maintenance process allows the system adminis- 
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Fig. 7. Application system startup The Monitor Control Pro- 
cess (MCP) is the lirst program to run in the application sys- 
tem Its first step is to launch the System Initialization Process 
(SIP) The SIP reads a prepared application data dictionary 
generated by the Application Customizer From this dictio- 
nary, the SIP builds system-wide tables used in operation and 
control ol the application system. The two mam tables gener- 
ated are the application control table (ACT) and the 
background job schedule Once the tables are initialized, the 
MCP begins normal operation and continues execution indefi- 
nitely 



trator to review and modify the background job processing 
schedule for the current day. Figs. 4 and 5 depict the user 
interface for the processing schedule maintenance process. 
System Messages Process (SMP). Messages informing the 
system administrator of the specifics of system activity can 
be reviewed by means of the system messages process. 
Certain messages may require a reply from the system ad- 
ministrator The reply can be processed using the SMP user 
interface, which is illustrated in Fig. 6. 

System Startup 

The monitor control process is the initial program to be 
run in the application system. The MCP is initiated by a 
user-defined command supplied with the installation 
software. This relieves the user of having to know the phys- 
ical file name of the MCP and any parameters that must be 
supplied. 

The MCP launches the system initialization process. The 
SIP reads the prepared application data dictionary gener- 
ated by the Customizer. This dictionary contains the follow- 
ing information critical to system operation and control: 

■ Terminal configuration 

■ Device configuration 

■ Schedule of interactive applications and their associated 
CRT terminals 

■ Schedule of all background jobs. 

Using this information, the system initialization process 
builds global tables to be used during that day's operation of 
the system. When initialization is complete, the MCP be- 
gins normal execution. 

Fig. 7 depicts the application system environment during 
system startup. 




Fig. 8. Interactive application management The Monitor Con- 
trol Process (MCP) reads the application control table (ACT) 
built by the System Initialization Process According to values 
initialized in the ACT the MCP launches application programs 
lor presentation ol application functions to users The applica- 
tion programs use Monitor intnnsics to request services and 
allow the system administrator to review and control applica- 
tion activities 
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Fig. 9. Background Job Management The Job Scheduler 
Process (JSP) reads the Background Job Schedule to deter- 
mine which jobs should be scheduled tor execution at the 
current time. All jobs that have run times on or betore the 
current time will be scheduled lor execution The Background 
Job Processor (BJP) executes a job by processing that yob's 
command Hie. Up to three BJPs may run concurrently, allow- 
ing concurrent execution of up to three background jobs. Each 
job may have recovery procedures and checkpoints defined 
It a job tails, the recovery procedures are automatically exe- 
cuted and the job is restarted at the appropriate checkpoint or 
step. 

Interactive Application Process Management 

Application processes are launched according to values 
initialized in the application control table. When the MCP 
initiates an application program it sends the program its 
process information block entry number. This entry 
number corresponds to a physical process information 
block in the application control table. By using this number 
in Monitor-supplied intrinsics. the application may per- 
form the following functions: 

■ Obtain information regarding which interactive terminal 
to use 

■ Start and communicate with a concurrent process to 
facilitate simultaneous processing of data 

■ Send a message to and start a successive process, sus- 
pending execution of the application until the successive 
process completes 

» Log transaction response time for review by the system 
administrator. 

Once the application system is in operation, interactive 
applications are automatically launched according to the 
schedule defined by the system administrator via the Cus- 
tomizes If the schedule defined for application initiation is 
accurate, no user interaction is necessary to gain access to 
application program functions. The appropriate applica- 
tion will be presented lo the appropriate set of users at the 
appropriate time. 

If special needs arise, the system administrator may mod- 
ify interactive application activity through the system ad- 
ministrator interface. 

Fig. 8 depicts the MCP's management of interactive ap- 
plications. 



Background Job Management 

Background jobs are scheduled for execution according 
to a list created by the system administrator via the Cus- 
tomizer. This list is read each day by the system initializa- 
tion process to determine the jobs to be run for the current 
day. 

The jobs are automatically executed at the time specified 
in the list. If a job fails, predefined recovery procedures are 
executed. When intervention is necessary, the system ad- 
ministrator may modify the execution sequence of 
background jobs via the processing schedule maintenance 
process. 

Fig. 9 depicts the Monitor's management of background 
jobs. 

Conclusion 

The Application Monitor is a major step in HP's long- 
term commitment to increase the ease ol use of application 
systems. The automation of an application system greatly 
reduces the time the system administrator must spend 
supervising operations and training operators. This allows 
more time for management of external functions in the 
environment where the applications are used. 
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Precision DVM Has Wide Dynamic 
Range and High Systems Speed 

This digital voltmeter makes precision laboratory 
measurements with 100-nanovolt dc resolution and 
two-ppm linearity. Variable integration time allows four-digit 
measurements at 300 readings per second. 

by Lawrence T. Jones, James J. Ressmeyer. and Charles A. Clark 



THE MODEL 3456A DIGITAL VOLTMETER (Fig. 1) 
is designed to handle most bench and system volt- 
age and resistance measurement problems. For the 
bench user, a calculator-style keypad, nine math functions 
(including conversion of thermistor resistance to t or °F) 
and reading storage facilitate many measurements formerly 
done with much effort, if at all. For systems use. the 
standard 3456A is compatible with the HP-IB.* Variable 
speed and resolution allow the user to tailor the voltmeter 
to the job at hand. Reading storage and program memory 
allow an HP-IB controller to perform other tasks while the 
voltmeter is running without the need lor time-consuming 
communications between them. 

Most of the versatility and improved speed of the 3456A 
comes from its integrating analog-to-digital (A-to-D) con- 
verter using the Multi-Slope II technique developed for this 
product. It can run in five different modes, trading off speed 

•Hewlelt-PactoO s impiementawn of IEEE Siancfa'd 488 r 1978) 



against resolution and precision. This tradeoff is made by 
the user specifying how long the input is to be integrated. 
The unit of time for this specification is one power line 
cycle (16.67 milliseconds for 60-Hz operation) and the in- 
tegration times available are 100. 10. 1. 0.1 and 0.01 power 
line cycles. The performance parameters affected by chang- 
ing the integration time are reading rate, line frequency 
rejection, accuracy, number of digits converted, and volt- 
meter electrical noise (see Fig. 2 and Fig. 3]. Power line 
noise is rejected by integrating for a period equal to an 
integral number of power line cycles. 

For the six-digit resolution of the A-to-D converter to be 
truly useful, it needs to be coupled with good linearity (±2 
ppm|. Fig. 4 shows the linearity of a typical unit. This level 
of performance makes the 3456A an extremely useful tool in 
a standards laboratory environment. 

The 3456A Digital Voltmeter measures dc volts on five 
ranges with 100-nV resolution on the lowest range and 
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Fig. 1 . The HP Model 3456A Digi- 
tal Voltmeter is a 3Vi-to-6Vi-digit. 
tutly-guarded integrating volt- 
meter with flexibility and precision, 
designed lor both bench and sys- 
tem measurement applications 
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Integration Time 
(Power Line Cycles) 

Fig. 2. The 3456A user can select measurement integration 
time to obtain the optimum combination ol reading rate, noise 
rejection, accuracy, internal noise, and displayable digits tor a 
particular application The relationship ol integration time to 
these parameters is shown above. 

1000 V full scale on (he highest. The accuracy over a 24-hour 
period at 10V is 10 ppm. For ac volts, the 3456A has a 
true-rms converter that measures on four ranges from 1.2V 
full scale to 700V full scale, all within 0.05% of midband 
reading. Resistance can be measured using either two-wire 
or four-wire measurements. Both functions have eight 
ranges with 100-/J.U resolution on the lowest and 1 Gfl full 
scale on the highest. Basic accuracy on the 1-kil and 10-kft 
ranges is 24 ppm at full scale. All functions are selectable 
from the front panel or from the I/O bus. 

Using the SHIFT key gives the operator five more func- 
tions. The RATIO REF terminals are used to measure a dc 
voltage for use as the denominator for three calculated ratio 
functions. These ratio functions first measure the voltage on 
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the volts terminals (dc. ac. or ac + dc). Next, they measure 
the dc voltage on the RATIO REF terminals and do a software 
division to arrive at the answer. Ratio reference measure- 
ment autoranges between the 0.1V, IV and 10V ranges. 

The last two functions are activated by shifting the ohms 
functions. These new voltmeter functions are called offset- 
compensated ohms. Resistance measurements, bolh two- 
and four-wire, can be made with these functions in the 
presence of offset voltages, such as thermal voltages. The 
voltmeter automatically takes the error voltages into ac- 
count and displays the correct resistance value. The offset- 
compensated ohms functions have four ranges: 10052 to 
10(1 kn full scale. 

The AUTO ZERO kej tuggles (he digital automatic zeroing 
function of the 345RA on and off. In stable environments the 
reading rate can be increased by a factor of almost two if 
AUTO ZERO is turned off. 

The FILTER key turns the active input filter on and off in 
dc voltage measurements. The filter has three poles at 5 Hz. 
giving 60 dB of rejection at 50 Hz. This key can also be used 
in ac volts measurements to extend the low-end frequency 
from 400 Hz down to 20 Hz. In ac measurements, the FILTER 
key turns on the input filter to filter (he output of the ac 
converter, and turns on a lower-frequency filter in the ac 
converter itself. A delay for filler settling is automatically 
added between readings when the filter is on. 

The TEST key puts the 3456A into a mode that cycles the 
instrument through a number of internal tests. II any of the 
tests fails, the failed test number is displayed. Any indi- 
vidual test can be run and the readings observed by storing 
the appropriate test number in the count register while in 
the test mode. The tes(s exercise all circuits in the 3456A 
including the various crossguard circuits, A-to-D converter, 
input amplifier, input switching, input filter, ohms mea- 
surement function and the ac converter. 

The systems user is given a new feature with the front 
panel SRQ key. This key activates the service request func- 
tion on the Hl'-IB. When supported by software in the sys- 
tem controller, this new channel of communication can 
initiate complex measurement tasks in any sequence. For 
example, in a production lesl application a technician may 
have five distinct test sequences. Using the SRQ key and a 
numerical entry, the technician can tell the controller 
which sequence to run. This feature lets a controller handle 
a number of 3456A test staUons from a central location. 
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Fig. 3. A typical 3456-4 DVM exhibits excellent noise perfor- 
mance with a selected integration time ol 100 power line 
cycles (sampling every three seconds) 
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Fig. 4. Typical linearity plot lor the WV range. 

The numeric keypad controls registers used in the math 
functions (see box below) and in voltmeter control. Volt- 
meter control registers are N (number of readings per 
trigger), G (number of digits displayed), D (delay from trig- 
ger to sample start), and I (number of power line cycles 
integrated over). Each of these registers can be set by the 
user according to the user's needs. 




(a) 



Rundown counts are converted 
to final reading 



(b) 



Rundown counts are converted 
to final reading 



Multi-Slope II 

To maintain the linearity and low-noise advantages of 
integration while decreasing the time needed to do a mea- 
surement, an improved A-to-D conversion technique 
(Multi-Slope II) was developed for the HP Model 3456A 
Digital Voltmeter. It was also highly desirable that ihe cost 



Fig. 5. The basic dual-slope A-to-D technique (a) has limited- 
conversion speed because the linal reading is not known until 
the ramp crosses zero during rundown. In the 3455.4 DVM 
multislope A-to-D technique (b). two rundown slopes are used 
to reduce the time required to determine the linal reading. The 
initial steep rundown slope reduces conversion time and is 
switched to a more gradual slope just prior to the zero crossing 
to provide a more accurate reading using a conventional- 
speed zero comparator 

of this circuit be kept relatively low. 

In addressing this problem, two principles were de- 
veloped: 

■ Do as much processing of the answer as possible during 
the measurement time. 

■ Microprocessors can add and subtract much faster than 
they can multiply. Therefore, potential gain errors 
should be converted into offset errors that can be sub- 
tracted oul. 

To understand the 3456A's A-to-D technique, con- 
sider the traditional dual-slope technique ( Fig. 5) used in 
several of HP's earlier DVMs. In this technique the un- 
known voltage causes the integrator to ramp for a fixed 
time (tmnupl- Then a known voltage is applied to the in- 
tegrator until the output crosses through zero. The lime re- 
quired for this crossover (t run( j ovvn ) is proportional to the 
unknown voltage and can be measured by a digital liming 
circuit (see Tig. 5a). 

This basic approach was refined during the evolution of 
HP system voltmeters. The A-to-D conversion technique 
used by Ihe 3455A Digital Voltmeter 1 reduces rundown 
time by first discharging the integrator at a fast rate and 
then switching to a slower rate until zero crossover (Fig, 5b). 



3456A Math Functions 

l/NULL: The first reading V, is subtracted from each succes- 
sive reading V n and the difference V n - V, is displayed ior each 
reading. 

2/STAT: The staiistics (unction accumulates Ihe number ol read- 
ings taken, the maximum and minimum readings, and the mean 
and variance of the readings In recallable registers The voltmeter 
displays each reading normally while this function is running. 
3/PASS/FAIL: The user enters the upper and lower limits Any 
reading outside of these limits will display HI or LO and pull Ihe 
service request line Readings inside the limits will be dis- 
played normally 

4'dBm|R): The user enters Ihe resistance R All readings are then 
displayed as power dissipated m the resistor in units of dB refer- 
enced to one milliwatt 

5/THMS °F: Thermistor linearization in degrees Farenheil With the 
voltmeter in ohms and a thermistor (HP part number 0837-0164 or 
equivalent), the reading is displayed in °F. 
6'THMS Same function as THMS °F but reading is displayed m 
degrees Celsius (°C) 

7'(X-Z)/Y: This linearization function allows the user to make both 
a zero correction and a slope or gam correction 1 ft 
8 ioo(X-Y)/Y: Percent deviation of Ihe reading X from the stored 
value Y 

9/20 log X/Y: The reading X is displayed In dB with respect to Ihe 
stored reference Y. 
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Fig. 6. The Multi-Slope II A-to-D technique used in the 3456A 
DVM uses lour slopes during the rundown period to deter- 
mine, in succession, the lour least-significant digits ol the 
linal reading. 

The 3456A DVM takes this improvement one step further. 
Initially, a steep slope S4 is applied until a zero crossing is 
detected. Next, a slope S3, one-tenth the magnitude ol S4 
and of opposite polarity, is applied until the integrator 
crosses back through zero. This process is repeated two 
more times, reducing Ihe slope magnitude by 90% and 
changing polarity each time, until the final slope SI passes 
through zero. Fig. B shows a typical rundown sequence. 

The multiple crossings at first may seem strange. The 
important point is to return the integrator to the same state 
at the end of the measurement as it was at the beginning 
(i.e.. zero volts]. The fact that S4 overshoots zero is ac- 



Input ramp 
for a large 
input voltage 



Integration Periods- 
Input Voltage Alone 

,-lnput Voltage + 
Reference Voltage 



Input ramp 
for a sma 
input voltage 




counts 10 counts 10 counts 10 counts 

'(Number of power line cycles selected by user) 

Fig. 7. During the integration time used in the Multi-Slope II 
method the reference voltage ramp is applied periodically at a 
fixed rate independent of the unknown input voltage level The 
polarity of the reference ramp during each period is depen- 
dent on the value of the sum of the previous ramp and the input 
voltage /ust before the previous ramp was turned off This 
approach reduces the voltage level at the end of the integra- 
tion time, thus reducing the demand on the integrator 
capacitor for low dielectric absorption. The number of positive 
reference ramps used during the integration time minus the 
number of negative ramps determines the most-significant 
digits of the reading. 



counted for in slope S3. Since each successive slops is 
exactly one decade smaller lhan the one preceding it, the 
microprocessor can accumulate the answer as each slope is 
applied. Each digit of the answer is stored in a register and 
each slope corresponds to a digit (Si corresponds to the 
least-significant digit (LSD). S2 to the next highest digit, 
and so on). The time that each slope was on is accumulated 
in its register while Ihe nexl slope is being counted. By the 
lime slope Si is crossing zero Ihe higher-order digits have 
been determined. 

The idea of accumulating the answer during the mea- 
surement can be extended to Ihe runup portion as well. By 
periodically applying a reference slope during runup (Fig. 
7) the most-significant digits can be converted during Ihe 
time the integrator is being charged. Increased dynamic 
range without sacrificing noise performance is another 
benefit. Fig. 7 shows the integrator output waveforms for 
two different voltage input levels to the 345(iA A-lo-D 
converter. During runup the reference slope is turned on 
periodically. The reference slope polarity used during each 
of the periods depends on the stale of the comparator just 
before the previous slope was turned off. Subtracting the 
number of limes that one reference slope polarity is on from 
the number of limes lhal the other is on determines the 
most-significant digits of Ihe answer. 

Increasing the length of runup allows more digits lo be 
converted at the cost of decreasing conversion speed. The 
3456A uses four integration limes lo obtain various speed/ 
resolution combinations. In its fastest mode the integration 
time is 167 microseconds (0.01 power line cycles (PLC)). In 
this mode the reference is never turned on during runup, 
allowing all four digits lo be converted during rundown. 
The five-digit mode integrates for 1.67 milliseconds (0.1 
PLC) so thai the most-significant digit (MSD) is converted 
during runup with the four LSDs converted during run- 
down. The longest integration time is 10 PLC. While only 
six digits are displayed, seven digits are actually converted 
with the LSD used as a guard digil lo give a very accurate 
six-digil measurement. Digitally averaging ten of these 
10-PLC measurements (equivalent to 100 PLC) allows very- 
low-level signals to be measured with less noise. 

Much effort was spent in the development of the 3456A 
A-lo-D converter to identify and eliminate major errors. 
A-to-D errors can be grouped in two classes. One is offset 
errors, thai is. the A-to-D does not read zero when the inpul 
is zero volts. The second is gain errors, that is. a 10-voh 
input does not give a 10-voll output. 

Offset errors are corrected by taking two measurements. 
The unknown vollage is measured and then followed by 
another measurement with the input shorted. Subtracting 
the second measurement from the first eliminates offset 
errors. For maximum speed the offset of the voltmeter can 
be measured only once and stored in a register. At the 
beginning of a reading the complement of this value is 
stored in the answer accumulator registers. As the mea- 
surement of the unknown voltage proceeds, each digit is 
added to its appropriate regisler. When ihe measurement 
cycle is complete the answer accumulator contains the 
measurement with the offset error voltage subtracted out. 

Small variations in the switching time of the reference 
vollage can cause errors in the final answer, in the A-to-D 
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converter of the 3455A DVM the number of times that the 
reference is turned on depends on the magnitude of the 
input voltage. This is a potential gain error. In the 3455A 
such gain errors are handled by measuring a known 10 
volts, calculating the error, and multiplying subsequent 
measurements by a correction factor. It was felt that 
this procedure takes too long to be used in the 345(iA. 
Every attempt was made to convert any potential gain errors 
into offsets. 

The Multi-Slope II technique holds the number of refer- 
ence voltage switch transitions constant regardless of the 
magnitude of the input. Timing errors are therefore the 
same for all inputs and can be subtracted out. 

The automatic zeroing scheme of the 34S8A uses a single 
reference to achieve both positive and negative-going 
ramps. A schematic of the integrator is shown in Fig. 8. 
When switches S], S 2 , S 3 , S 4+ and S 4 _ are switched to 
ground the current I from the + 12Vsupply goes through the 
summing node into the integrating capacitor C (the sum- 
ming node is at virtual ground). This generates a negative 
ramp at the integrator output. 

If both S»4 and $4- are switched to the -12V reference, 
twice the current |2I) supplied by the + 12V supply alone is 
drawn through the parallel paths of R 4 . and R 4 _. The extra 
current must be drawn from the integrating capacitor to the 
summing node, which causes a positive ramp to be gener- 
ated at the output of the integrator. 

Between measurements an automatic zeroing opera- 
tion is performed. S 4 _ and S 2 are switched to the -12V 
reference and Sj, S 3 and S 4 _are connected to ground. Be- 
cause the parallel combination of resistors R 2 and R^ is 
approximately equal to resistor R, any difference A be- 
tween the + 12V and the -12V references will appear at the 
summing node as A/2 when switch S z is closed. This error 
term A/2 is stored on the autozero capacitor C z when S z is 
opened. During ramp generation. S z is open and the posi- 
tive terminal of the operational amplifier is at A/2, which 
corrects for the A error in the positive supply. The + 12V 
supply needs only to have good short-term stability since 
the +12V error is converted to an offset and subtracted out. 

Another potential source of error is hysteresis in the zero 
comparator. To combat this problem the rundown slopes 
are arranged so that the final zero crossing always occurs in 
the same direction. To discharge integrator voltages ol both 



- 12V Reference 



Fig. 8. - highly simplified 
schematic ol the integrator and 
surrounding circuitry Two auto- 
zero systems are used —a digital 
method using a separate mea- 
surement cycle to determine the 
olfset error and an analog 
technique where the autozero 
capacitor C z is used to store any 
offsets produced at the input to the 
integrator. 



polarities, two S4 slopes of the same magnitude, but differ- 
ent polarities, are used. The length of time that each S4 
polarity is on depends on the magnitude and polarity of the 
voltage to be discharged (Fig. 9). Note that both positive and 
negative-polarity slopes are only needed for the most- 
significant slope S4. These ramps are generated by closing 
the appropriately identified switches in Fig. 8. The 
negative-going slope S2 is obtained by connecting switch 
S 2 to ground because it was connected to -12V during the 
automatic zeroing cycle. 

To minimize cost, one of the design goals was to devise an 
algorithm requiring a minimum of precision parts. The 
-12V reference, the set of tantalum-nitride resistors that 
produces the slopes, and a low-noise FET input for the inte- 
grator are the only precision components required. The criti- 
cal slope switches are a digital CMOS inverter pack con- 
nected as shown in Fig. 10, Only one adjustment to the -12V 
reference is needed to calibrate the A-to-D converter. 

What's Inside 

Fig. 11 shows a block diagram of the paths taken by 
various signals. The input switching block has two basic 
functions, One is to complete the signal paths for a given 
voltmeter configuration. The second is to multiplex the 




Fig. 9. Switch transitions and direction ol the zero crossings 
are kept consistent by Ihe use of an extra S4 slope ot opposite 
polarity. This slope (dashed line) ensures that the zero cross- 
ing tor slope S3 occurs always from the same direction 
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Fig. 10. The slope switches shown in Fig. 8 are CMOS 
inverters. 

measuring terminals for the measurement cycle. For each 
signal condition, a correctly scaled, low-ripple voltage is 
presented to the A-to-D converter. Tor dc volts the signal 
conditioner is the dc input amplifier, and for dc signals 
that have large ac components, the low-pass filter is 
added to attenuate them. Forac volts the scaled dc voltage is 
supplied by the ac converter. For frequencies below 400 Hz 
the low-pass filter is also connected. The gain in the input 
amplifier is set at one. For resistance measurements, cor- 
rectly scaled current is passed through the unknown resis- 
tor. Thedc input amplifier is set at a gain of 100 for the lOOfl 
range, a gain of 10 for the 1-kS2and 10-kii ranges, and a gain 
of 2 for the remaining resistance ranges. The current source 
used in the 3456A is referenced to the voltmeter's LO termi- 
nal. This eliminates the separate floating power supplies 
that would be required if the current source were floating. 
When lead impedance is a concern, the 3456A can be used 
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in a four-wire mode. In this mode the current is passed 
through the unknown resistor via the HI and LO terminals 
and the voltage drop is sensed via the HI and LO SI sense 
terminals, which float with respect to the voltmeter LO 
terminal and therefore the current source. These terminals 
are also used for the ratio reference when the 3456A mea- 
sures voltage ratios. 

Autocalibration schemes are often used to correct lor 
internal errors in voltmeters. These errors or autocalibra- 
tion constants are measured between readings. The se- 
quence is measure unknown, measure constant, measure 
unknown, measure constant and so on. In the HP Model 
3455A Digital Voltmeter 1 there are 13 autocalibration con- 
stants that are stored in instrument memory. This takes time 



Input 




Fig. 11. Block diagram of the 3456A Digital Voltmeter 



Output 



Fig. 12. Simplified schematic of the resistive ac attenuator 
Virtual-ground switching at the amplifier inputs provides good 
range isolation and eliminates the need for a gate bias Table I 
above indicates the switch closures required for each range 
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and puis some rigorous requirements on the input switch- 
ing. For instance. lOOOVdc must be isolated while measur- 
ing the accuracy of the high-voltage attenuator. 

in the 3456A. gain errors due to the instrument reference 
and dc input amplifier are adjusted out by the front-panel 
calibration procedure. The error left is the offset of the dc 
input amplifier. This is removed by an automatic zeroing 
scheme. With AUTO ZERO on. each measurement really 
consists of two measurements. The first measurement is the 
unknown voltage plus the dc input amplifier offset (volt- 
meter HI). The second measurement is the dc input 
amplifier offset (voltmeter LO). These two measurements 
are subtracted, leaving only the unknown voltage as the 
answer. With AUTO ZERO off, instrument LO is measured 
and stored by the inguard controller. The measurement 
cycle then consists only of measuring the HI terminal volt- 
age and subtracting the stored value. Note that for any 
instrument reconfiguration the offset must be updated and 
this is done automatically. With automatic zeroing the 
input switching becomes much simpler and more reliable. 
For instance, only five relays are required for voltage and/or 
function block isolation, compared with as many as thirteen 
for the 3455A instrument using AUTO CAL. 

ac Resistive Attenuator 

A resistive attenuator. Fig. 12, is used in the 3456A ac 
converter. Using fineline thin-film resistors, high-gain 
negative feedback and virtual-ground switching at the 
input to the operational amplifiers, the attenuator has a 
-3-dB point at 1 MHz and range isolation greater than 88 
dB at 100 kHz. Besides low cost, the big advantage of the 
attenuator is that it has only one adjustment. This adjust- 
ment is available at the front panel; it corrects for the at- 
trnu.itur ( illset. 

Two types of adjustments generally needed in ac at- 
tenuators are those for low-frequency gain and high- 
frequency flatness. If the thin-film resistors are trimmed 
properly, the scaled output of each range at low frequencies 
can be made to agree within =0,01%. Oilier components 
affect full-scale accuracy. I lowever, I hey drifl with lime at a 
rate al least len limes greater than the resistor ratio, so there 
is no need to provide periodic correction of this ratio. To 
obtain range-lo-range tracking with frequency, high-gain 
negative feedback is used. Each range has the same loop 
gain characteristics. Therefore, when the loops are closed 
their frequency responses are equal. 

Because of the number of switches used to achieve range 
selection, there is a capacilance of 27 to 33 pF at the sum- 
ming junction of amplifier Al in Fig. 12. To get and main- 
lain good frequency response with the impedance levels 
used, amplifier Al has only one pole below 5 MHz and has 
swilchable gain-bandwidth. For instance, when used in 
the IV range, a minimum gain-bandwidth product of 
100 MHz is required. 

Since the attenuator is uncompensated (resistive-only), 
the resistor ratios must hold nol only at dcand low frequen- 
cies, but at high frequencies also. To insure this, the japaci- 
tance across the one-megohm input resistor must be kepi as 
low as possible. To get a one-megohm resistor with flat- 
enough frequency characteristics, a three-wire technique is 
employed, A third wire is held al ground potential and 
brought Into close proximity to the input and output termi- 



nals of the 1-Mfl resistor. This shunts some of the capaci- 
tance to ground thai would otherwise shunt the resistor. 
With this technique the transfer capacitance is 0.15 pF. 
ten times better than that for two-wire techniques. This 
resistor also has the capability of handling high-voltage 
pulses up to 3 kV without damage. See Fig. 13 for a photo- 
graph of the fineline thin-film resistor chip used in the 
3456A's ac converter. 

Wide Dynamic Ohms Measurement 

Using the input switching and arithmetic capability of 
the outguard processor, the ohms function achieves a wide 
dynamic range. The measurement of low resistance values 
can be enhanced by using the offset-compensated ohms 
function. This function takes two separate samples of the 
unknown. The first sample is taken with the current source 
turned on and the second is taken with the current source 
turned off. The second sample measures the voltage on the 
unknown not caused by (he current source. This voltage 
adds to the voltage generated by the current source and 
causes an error. This error voltage is subtracted from the 
first sample to give the true voltage caused by the current 
source in the resistor. 

The importance of this function is demonstraled when 
the magnitudes of some signal and error voltages are com- 
pared. One type of error voltage is generated thermally by 
dissimilar metals in the measurement circuit. A metal film 
resistor can generate voltages on the order of many mi- 
crovolts where the resistive metal film contacts its own 
copper leads. On the 100ft range the current source puts out 
1 raA. The resolution in the six-digit mode is 100 nil which 




Fig. 13. Magnified view of the tinehne resistor chip (821 0C) 
used in the ac converter The I-Mll input resistor is in the 
upper left corner Note the contact pads rounded tor high 
voltage and larger than usual area lor heat dissipation The 
third wire mentioned in the text lor reducing transfer capaci- 
tance is located on the printed circuit board on which this 
5-mm-square chip is mounted 
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Voltmeter Stores Measurement 
Instructions and Data 



The HP Model 3456A Digital Voltmeter has an internal memory 
(RAM) that can be used to store the results of measurements and 
the instructions for taking the measurements This capability al- 
lows an HP-IB controller to input a shon data-gathering program 
to the 3456A and then be abie to address other instruments on the 
bus while the 3456A takes and stores readings A typical set of 
ASCII alphanumeric strings output on the HP-IB lo the 3456A by a 
controller is given below (the spaces are optional and included 
here lo separate individual commands for discussion) 

"L1 F2 ZO 1STI DO P1 30STN 0.05STD RSl T3" 

"F1 10STN OSTD T3" 

"F3 R4 20STN 0.01 STI T3 RSO P0 Q" 

This program can be executed al any time by sending the al- 
phanumeric string "HX1" on the HP-IB to the 3456A The first line 
indicates the beginning of the program and tells the voltmeter to 
take 30 ac-volt measurements and store them in packed format m 
the internal memory The second line tells the 3456A to take and 
store 10 low-level dc-volt readings with normal-mode rejection 
(NMR) The last line takes 20 thermistor resistance measurements 
at 300 readings per second and indicates the end of the program. 

Most of the commands are related to the location of the appro- 
priate key on the front panel of Ihe 3456A For example, dc volts is 
the first function key, hence F1 is Ihe command Similarly F2. F3. 



F4. and F5 indicate the second, third, fourth and fifth lunction keys 
corresponding to ac volts, ac-plus-dc volts, two-wire kilohms and 
four-wire kilohms. respectively Code definitions for other com- 
mands m the above program are 

L1 - Marks the beginning of a sequence to be stored in program 

memory 
Z0 - Turns AUTO ZERO off 

1STI - Selects one power-lme-cycle integration time 

DO - Turns the display off. 

Pi - Turns the packed data mode on 

30STN - Thirty readings to be taken per trigger 

0 05STD - Store 50-ms delay between measurement cycles 

RS1 - Turns readings stored on 

T3 - Triggers Ihe number of readings previously programmed 
OSTD - Removes delay between readings 
R4 - Selects the 10-ki 1 range. 
RSO - Stop storing data 
P0 - Packed mode off 

O - Marks the end of the program to be stored m the internal 
RAM. 

H - Software RESET (autorangmg on dc-volts function, ten 

power-line-cycles integration time, AUTO ZERO on). 
X1 - Executes program stored in the internal RAM 



corresponds to measuring 100 nV across the unknown re- 
sistor. Thus, thermally-generated error voltages can cause 
large errors on the more sensitive resistance ranges. By using 
the offset-compensated ohms function these errors are re- 
moved so that low resistance can be measured accurately. 

On the other end of the dynamic range, high-resistance 
measurements have been expanded through use of a 
calculated-resistance technique. The 100-Mfl and the 1-Gft 



ranges use the same signal current as the 10-Mft range. The 
unknown resistor is paralleled with a known 10-Mft resistor 
in the Input switching. Hence, the resistance measured is the 
parallel combination of the unknown resistor R x and 10 Mil. 
The value of the unknown can then be computed from the 
formula: 



luMft- R, 
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where R m is the measured parallel resistance. 

System Planning for High Speed 

Numerous features have been designed into the 3456A 
specifically for systems use. Included in these is a 
voltmeter-complete output. This rear-panel digital output 
switches from a low to a high logic level (from0to5V) when 
the voltmeter is finished measuring the input signal. The 
voltmeter-complete signal can be used in conjunction with 
external triggering and a channel-closed signal from a 
scanner to make a high-speed scanning loop that is inde- 
pendent of the controller. Also useful in this type of appli- 
cation are a programmable delay between readings and a 
programmable number of readings per trigger. 

HP-IB is standard in the 3456A. All functions available 
from the front panel are also available under remote control. 
Some systems features that would not be useful to the bench 
user are accessible only under remote control. A DISPLAY 
OFF command allows a taster reading rate because the pro- 
cessor does not have to format the data for the display. A 
packed mode output speeds up the system reading rate 
because only four bytes of packed information are sent out. 
compared to 14 bytes in the unpacked mode. 

An internal RAM is available to the systems user to be 
used for reading storage and/or program memory. Although 
reading storage can also be accessed from the front panel, 
program memory is a remote operation only. When there is 
no program in memory. 350 readings can be stored. Using 
program memory, any sequence of functions, including 
reading storage, can be performed without intervention by 
the controller. This allows readings to be taken and stored 
in different configurations when the controller is busy 
doing other tasks. An example ol how program memory is 
used is shown in the box on the left. 

Maintenance and Calibration 

Extra design effort was expended on the 3456A to 
.simplify maintenance and calibration both electrically and 
mechanically. Calibration of the complete voltmeter can be 
accomplished by removing the front-panel calibration plate 
(see Fig. 14). connecting the correct standards, and adjust- 
ing the front-panel settings. There are 14 adjustments: five 
for dc volts, four for ac volts and live lor ohms. 

All printed circuit boards containing active circuitry, 
except these board, are readily accessible by removing four 
screws. To access the ac board, the four screws holding its 
shield on must also be removed. 
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CREST FACTOR ' i m W 

COHHON MODE REJECTION i - Nil gnbMnc* ai LOi -90 OB. * B E0 "M 
INPUT IMPEDANCE ' Mil - 0 S% Mximefl 0, - WpF 

Resistance 

INPUT CHARACTERISTICS iCr-aon irooa 10 PlC .nag-anon Itmel Fleet f| iyn opw* 
RANGE MAXIMUM READiNO^SOLUTION, CURRENT THROUGH UNKNOWN 
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O IV, • OV. AND lOV RANGES M0.**Jl 
100V AMD 1000V RANGES 10M!!z0 5% 
NOISE H EJECTION t 1 ml unOUanea m lO| 

■cNMR OdB 1001 o/0 1 PLCi. BOdBi '' RLCl 120 UBl-'i PLC HfetlflM 
■ft CMR 90dB(0Di w 0 1 PLC) ISO OB t ■< I PLC| ISO UB I --1 PlC a>im Men 
ocOMR i4adB 

ac ims Voltage 

(NPUt CHARACTERISTICS 6'*-<»U» moOo 15 PIC mlvrxtuyi M| 
HANGC MAXIMUM READINO' RESOLUTION 
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O' raa<]<ng • -u*n*f ol court HI AUTO ZERO or FILTETt o" %UHi\ 
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N0N0E5THUCT1VE OVEHLOAD: 350V pea" 

1W0 WIRI OMMS ACCURACY Sama as la.n *n> om% aoc a m 

f/02ii r#M* 

OFFSET COMPENSATED OHMS ACCURACY: Same an i-0--*o laun 
C«p< ma* "ten ■aaO^g may be isducad Dy 9*. lo> largs 3"w mnaoe^ 

Ratio 

TYPE ac* tede »i« - dcMX Range i* BiAwnahtalt. uHectao 
METHOD: I W wW VOLT 5 lO -«i4 CTWinon FILTER ■ all 

RATIO Svnai Vo"aq» l iR«'»i»ntt- Hi VOAage Wtmn* LO Voyager 
MAHMuM REFERENCE VOLTAGES 

REFERERCE HI :12V. 



RE *E HENCE lO -9H ol laTOeow hi 
REFERENCE Mi REFERE'ICC LO - H 9999V 
PROTECTION -3S0Vp«t* 
ACCURACY: T00U ftft aqnal n"oi phi* t,.tu % '•Nwanta a"0> IMrne a* 0 IV IfiV. •> 
lOVOc »mm| 

Reading Rate 

INTEGRATION TIME AUTO ZERO OFF AUTO ZERO ON: RoaoVg -aMa PC metre ate 
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GENERAL Main Ijkivw speptcanon* 00 no- iTOjOo amn ir 

enured .alum (R. L U. Y Z) Range tf «MUM ««mI o OUbul II 0 000000 • 
• 1999999 • 13 s Ojrcf'ange values MftJ OL to tne dtMUy aid 
lO 8 10 HP-IB 

FUNCTIONS AVAILABLE Itor lurthei deKirplion aee Mi on page25l P»-*ai' unianci 

i\0 oBnyRj. ■nafmino* ( : P| Uwintw ( Cj ecaN. n woi end dB 

General 

MAXIMUM INPUT VOLTAGE 1*1 <V. eOO ac 'BTOetl r 1000V p*a* (TOOVrmai KPVHi 

GUARO TO CHASSIS. ;500V peak 

GUARD TO LO: :200V peak 
MEMORY SIZE: Total vj- - 1400 Dvlai Mvmoty v«ed 1* one Kyia pat ASCH duvacto- 

Dtot tout pa 'eMing 110100 

VOLTMETER CONTROL FUNCTIONS: Numb* ol O0W OUpttyed |3 W 0). min*a> 0* 

leaotngs per irigget delay I«ne bat-aan meMMrernoiO 10 10 990 WW > « I ma >neie- 

m#rn| and moaajreomnt MbjatCSII Mi 10 1 lo '00 poaw »ne cyOMi 
OPERATING TEMPERATURE RANGE: 0 In 50"C 
WARMUP TIME 1 On- hi»ii to "Mel *U «*cilcanon» 
HUMOrrr RANGE »% ivsvw numdiiy 0 10 ACC 
STORAGE TEMPERATUHE RANGE: 40 to 7513 

POWER:4Bio6S-Hiiinaooe'aiion.«ivA I»'ffl3«0 V«c - W >OVoHOVac :1D-. 

SIZE IHWDI: BS 9 • 425 5 ■ 537 1 mm 

WEIGHT Nrt 10 49 ^. Vuppng 13 35 eg 

PRICE IN USA Mooal 34SHA DiDilal VoCnetei. 13500 00 
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